home *** CD-ROM | disk | FTP | other *** search
/ MacTech 1 to 12 / MacTech-vol-1-12.toast / Source / develop™ Technical Journal / develop Issue 9 code / Tracks.sea / Tracks / drvr.c < prev    next >
MacBinary  |  1992-11-16  |  39.1 KB  |  [TEXT/MPS ]

open in: MacOS 8.1     |     Win98     |     DOS

browse contents    |     view JSON data     |     view as text


This file was processed as: MacBinary (archive/macBinary).

ConfidenceProgramDetectionMatch TypeSupport
66% dexvert Compact Compressed (Unix) (archive/compact) ext Supported
10% dexvert MacBinary (archive/macBinary) fallback Supported
10% dexvert Jesper Olsen Module (music/jesperOlsen) magic Supported
1% dexvert Text File (text/txt) fallback Supported
100% file MacBinary II, inited, Mon Nov 16 17:42:06 1992, modified Mon Nov 16 17:42:06 1992, creator 'MPS ', type ASCII, 39334 bytes "drvr.c" , at 0x9a26 428 bytes resource default (weak)
99% file data default
49% TrID Macintosh plain text (MacBinary) default
33% TrID TTComp archive compressed (bin-4K) default (weak)
16% TrID MacBinary 2 default (weak)
100% siegfried fmt/1762 MacBinary (II) default
100% lsar MacBinary default


id metadata
keyvalue
macFileType[TEXT]
macFileCreator[MPS ]



hex view
+--------+-------------------------+-------------------------+--------+--------+
|00000000| 00 06 64 72 76 72 2e 63 | 00 00 00 00 00 00 00 00 |..drvr.c|........|
|00000010| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000020| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000030| 00 00 00 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |........|........|
|00000040| 00 54 45 58 54 4d 50 53 | 20 01 00 00 00 00 00 00 |.TEXTMPS| .......|
|00000050| 00 00 00 00 00 99 a6 00 | 00 01 ac a7 2d d4 3e a7 |........|....-.>.|
|00000060| 2d d4 3e 00 00 00 00 00 | 00 00 00 00 00 00 00 00 |-.>.....|........|
|00000070| 00 00 00 00 00 00 00 00 | 00 00 81 81 78 c7 00 00 |........|....x...|
|00000080| 23 69 6e 63 6c 75 64 65 | 20 22 54 72 61 63 65 4d |#include| "TraceM|
|00000090| 6f 64 75 6c 65 2e 68 22 | 0d 23 69 6e 63 6c 75 64 |odule.h"|.#includ|
|000000a0| 65 20 3c 54 6f 6f 6c 55 | 74 69 6c 73 2e 68 3e 0d |e <ToolU|tils.h>.|
|000000b0| 23 69 6e 63 6c 75 64 65 | 20 3c 45 72 72 6f 72 73 |#include| <Errors|
|000000c0| 2e 68 3e 0d 23 69 6e 63 | 6c 75 64 65 20 3c 46 69 |.h>.#inc|lude <Fi|
|000000d0| 6c 65 73 2e 68 3e 0d 23 | 69 6e 63 6c 75 64 65 20 |les.h>.#|include |
|000000e0| 3c 4d 65 6d 6f 72 79 2e | 68 3e 3e 0d 23 69 6e 63 |<Memory.|h>>.#inc|
|000000f0| 6c 75 64 65 20 3c 53 74 | 72 69 6e 67 73 2e 68 3e |lude <St|rings.h>|
|00000100| 0d 23 69 6e 63 6c 75 64 | 65 20 3c 4f 53 55 74 69 |.#includ|e <OSUti|
|00000110| 6c 73 2e 68 3e 0d 23 69 | 6e 63 6c 75 64 65 20 3c |ls.h>.#i|nclude <|
|00000120| 45 76 65 6e 74 73 2e 68 | 3e 0d 23 69 6e 63 6c 75 |Events.h|>.#inclu|
|00000130| 64 65 20 3c 52 65 73 6f | 75 72 63 65 73 2e 68 3e |de <Reso|urces.h>|
|00000140| 0d 23 69 6e 63 6c 75 64 | 65 20 3c 44 65 76 69 63 |.#includ|e <Devic|
|00000150| 65 73 2e 68 3e 0d 23 69 | 6e 63 6c 75 64 65 20 3c |es.h>.#i|nclude <|
|00000160| 74 79 70 65 73 2e 68 3e | 20 09 2f 2f 20 4d 61 63 |types.h>| .// Mac|
|00000170| 20 74 79 70 65 73 0d 23 | 69 6e 63 6c 75 64 65 20 | types.#|include |
|00000180| 3c 44 65 73 6b 2e 68 3e | 09 2f 2a 20 66 6f 72 20 |<Desk.h>|./* for |
|00000190| 61 63 63 52 75 6e 20 2a | 2f 0d 2f 2a 2a 2a 2a 2a |accRun *|/./*****|
|000001a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000001b0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000001c0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000001d0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000001e0| 2a 2a 0d 2f 2f 0d 2f 2f | 20 54 72 61 63 6b 73 20 |**.//.//| Tracks |
|000001f0| 44 72 69 76 65 72 0d 2f | 2f 20 43 6f 70 79 72 69 |Driver./|/ Copyri|
|00000200| 67 68 74 20 31 39 39 30 | 2c 20 31 39 39 31 20 4f |ght 1990|, 1991 O|
|00000210| 72 69 6f 6e 20 4e 65 74 | 77 6f 72 6b 20 53 79 73 |rion Net|work Sys|
|00000220| 74 65 6d 73 2c 20 49 6e | 63 2e 20 41 6c 6c 20 52 |tems, In|c. All R|
|00000230| 69 67 68 74 73 20 52 65 | 73 65 72 76 65 64 2e 0d |ights Re|served..|
|00000240| 2f 2f 20 41 75 74 68 6f | 72 73 20 3a 20 20 4a 69 |// Autho|rs : Ji|
|00000250| 6d 20 46 6c 6f 6f 64 2c | 20 42 72 61 64 20 4c 6f |m Flood,| Brad Lo|
|00000260| 77 65 0d 2f 2f 0d 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |we.//.**|********|
|00000270| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000280| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|00000290| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2a 2a |********|********|
|000002a0| 2a 2a 2a 2a 2a 2a 2a 2a | 2a 2a 2a 2a 2a 2a 2f 0d |********|******/.|
|000002b0| 0d 0d 2f 2f 20 63 6c 65 | 61 72 73 20 63 69 72 63 |..// cle|ars circ|
|000002c0| 75 6c 61 72 20 62 75 66 | 66 65 72 20 62 79 20 73 |ular buf|fer by s|
|000002d0| 65 74 74 69 6e 67 20 73 | 74 61 72 74 20 61 6e 64 |etting s|tart and|
|000002e0| 20 65 6e 64 20 74 6f 20 | 74 68 65 20 73 61 6d 65 | end to |the same|
|000002f0| 20 70 6c 61 63 65 0d 73 | 6e 75 6d 20 43 6c 65 61 | place.s|num Clea|
|00000300| 72 54 72 61 63 65 42 75 | 66 66 65 72 28 54 72 61 |rTraceBu|ffer(Tra|
|00000310| 63 65 47 6c 6f 62 61 6c | 73 20 2a 67 6c 6f 62 61 |ceGlobal|s *globa|
|00000320| 6c 73 29 0d 7b 0d 72 65 | 67 69 73 74 65 72 20 73 |ls).{.re|gister s|
|00000330| 68 6f 72 74 20 09 72 65 | 73 75 6c 74 3b 0d 0d 09 |hort .re|sult;...|
|00000340| 69 66 20 28 20 21 20 67 | 6c 6f 62 61 6c 73 2d 3e |if ( ! g|lobals->|
|00000350| 66 42 75 66 66 65 72 45 | 6e 61 62 6c 65 64 29 0d |fBufferE|nabled).|
|00000360| 09 09 72 65 73 75 6c 74 | 20 3d 20 66 6e 4f 70 6e |..result| = fnOpn|
|00000370| 45 72 72 3b 20 2f 2f 20 | 22 46 69 6c 65 20 6e 6f |Err; // |"File no|
|00000380| 74 20 6f 70 65 6e 22 20 | 6d 65 61 6e 73 20 74 72 |t open" |means tr|
|00000390| 61 63 65 20 69 73 20 6e | 6f 74 20 65 6e 61 62 6c |ace is n|ot enabl|
|000003a0| 65 64 0d 09 65 6c 73 65 | 0d 09 7b 0d 09 09 72 65 |ed..else|..{...re|
|000003b0| 73 75 6c 74 20 3d 20 6e | 6f 45 72 72 3b 0d 09 09 |sult = n|oErr;...|
|000003c0| 2f 2f 09 77 68 65 6e 20 | 6e 65 78 74 52 65 61 64 |//.when |nextRead|
|000003d0| 20 3d 3d 20 6e 65 78 74 | 57 72 69 74 65 20 74 68 | == next|Write th|
|000003e0| 65 20 62 75 66 66 65 72 | 20 69 73 20 65 6d 70 74 |e buffer| is empt|
|000003f0| 79 2e 2e 0d 09 09 2f 2f | 20 09 4d 61 6b 65 20 69 |y.....//| .Make i|
|00000400| 74 20 73 6f 0d 09 09 67 | 6c 6f 62 61 6c 73 2d 3e |t so...g|lobals->|
|00000410| 66 4e 65 78 74 52 65 61 | 64 50 74 72 20 3d 20 67 |fNextRea|dPtr = g|
|00000420| 6c 6f 62 61 6c 73 2d 3e | 66 42 75 66 66 53 74 61 |lobals->|fBuffSta|
|00000430| 72 74 50 74 72 3b 0d 09 | 09 67 6c 6f 62 61 6c 73 |rtPtr;..|.globals|
|00000440| 2d 3e 66 4e 65 78 74 57 | 72 69 74 65 50 74 72 20 |->fNextW|ritePtr |
|00000450| 3d 20 67 6c 6f 62 61 6c | 73 2d 3e 66 42 75 66 66 |= global|s->fBuff|
|00000460| 53 74 61 72 74 50 74 72 | 3b 09 0d 09 7d 0d 09 72 |StartPtr|;...}..r|
|00000470| 65 74 75 72 6e 28 72 65 | 73 75 6c 74 29 3b 0d 7d |eturn(re|sult);.}|
|00000480| 0d 0d 2f 2f 20 45 61 63 | 68 20 77 72 69 74 65 20 |..// Eac|h write |
|00000490| 74 6f 20 74 68 65 20 66 | 69 6c 65 20 6f 70 65 6e |to the f|ile open|
|000004a0| 73 2c 20 77 72 69 74 65 | 73 20 61 6e 64 20 63 6c |s, write|s and cl|
|000004b0| 6f 73 65 73 20 74 68 65 | 20 66 69 6c 65 2e 20 20 |oses the| file. |
|000004c0| 54 68 69 73 20 66 75 6e | 63 74 69 6f 6e 0d 2f 2f |This fun|ction.//|
|000004d0| 20 63 6c 6f 73 65 73 20 | 74 68 65 20 6f 75 74 70 | closes |the outp|
|000004e0| 75 74 20 66 69 6c 65 2e | 0d 73 6e 75 6d 20 43 6c |ut file.|.snum Cl|
|000004f0| 6f 73 65 54 72 61 63 65 | 46 69 6c 65 28 54 72 61 |oseTrace|File(Tra|
|00000500| 63 65 47 6c 6f 62 61 6c | 73 20 2a 67 6c 6f 62 61 |ceGlobal|s *globa|
|00000510| 6c 73 29 0d 7b 0d 72 65 | 67 69 73 74 65 72 09 73 |ls).{.re|gister.s|
|00000520| 6e 75 6d 20 72 65 73 75 | 6c 74 3b 0d 09 69 66 20 |num resu|lt;..if |
|00000530| 28 20 21 20 67 6c 6f 62 | 61 6c 73 2d 3e 66 46 69 |( ! glob|als->fFi|
|00000540| 6c 65 49 73 4f 70 65 6e | 29 0d 09 09 72 65 73 75 |leIsOpen|)...resu|
|00000550| 6c 74 20 3d 20 66 6e 4f | 70 6e 45 72 72 3b 20 2f |lt = fnO|pnErr; /|
|00000560| 2f 20 22 46 69 6c 65 20 | 6e 6f 74 20 6f 70 65 6e |/ "File |not open|
|00000570| 22 20 45 72 72 6f 72 20 | 2d 33 38 0d 09 65 6c 73 |" Error |-38..els|
|00000580| 65 0d 09 09 7b 0d 09 09 | 2f 2f 20 43 6c 6f 73 65 |e...{...|// Close|
|00000590| 20 74 68 65 20 66 69 6c | 65 20 61 6e 64 20 66 6c | the fil|e and fl|
|000005a0| 75 73 68 20 74 68 65 20 | 76 6f 6c 75 6d 65 2e 0d |ush the |volume..|
|000005b0| 09 09 2f 2f 20 53 65 74 | 20 66 46 69 6c 65 49 73 |..// Set| fFileIs|
|000005c0| 4f 70 65 6e 20 74 6f 20 | 66 61 6c 73 65 20 0d 0d |Open to |false ..|
|000005d0| 0d 09 09 72 65 73 75 6c | 74 20 3d 20 46 53 43 6c |...resul|t = FSCl|
|000005e0| 6f 73 65 28 67 6c 6f 62 | 61 6c 73 2d 3e 66 46 69 |ose(glob|als->fFi|
|000005f0| 6c 65 52 65 66 4e 75 6d | 29 3b 0d 09 09 69 66 20 |leRefNum|);...if |
|00000600| 28 72 65 73 75 6c 74 20 | 3d 3d 20 6e 6f 45 72 72 |(result |== noErr|
|00000610| 29 09 2f 2a 20 54 68 69 | 73 20 77 6f 75 6c 64 20 |)./* Thi|s would |
|00000620| 62 65 20 69 73 20 76 65 | 72 79 20 6f 64 64 20 69 |be is ve|ry odd i|
|00000630| 66 20 21 74 72 75 65 2e | 2e 2e 20 2a 2f 0d 09 09 |f !true.|.. */...|
|00000640| 09 7b 0d 09 09 09 67 6c | 6f 62 61 6c 73 2d 3e 66 |.{....gl|obals->f|
|00000650| 46 69 6c 65 49 73 4f 70 | 65 6e 20 3d 20 66 61 6c |FileIsOp|en = fal|
|00000660| 73 65 3b 0d 09 09 09 72 | 65 73 75 6c 74 20 3d 20 |se;....r|esult = |
|00000670| 46 6c 75 73 68 56 6f 6c | 28 6e 69 6c 2c 20 67 6c |FlushVol|(nil, gl|
|00000680| 6f 62 61 6c 73 2d 3e 66 | 56 52 65 66 4e 75 6d 29 |obals->f|VRefNum)|
|00000690| 3b 0d 09 09 09 7d 0d 09 | 09 2f 2f 20 28 76 6f 69 |;....}..|.// (voi|
|000006a0| 64 29 20 53 65 74 46 4c | 6f 63 6b 28 67 6c 6f 62 |d) SetFL|ock(glob|
|000006b0| 61 6c 73 2d 3e 66 54 72 | 61 63 65 46 69 6c 65 4e |als->fTr|aceFileN|
|000006c0| 61 6d 65 2c 20 67 6c 6f | 62 61 6c 73 2d 3e 66 56 |ame, glo|bals->fV|
|000006d0| 52 65 66 4e 75 6d 29 3b | 0d 09 09 7d 0d 09 72 65 |RefNum);|...}..re|
|000006e0| 74 75 72 6e 28 72 65 73 | 75 6c 74 29 3b 0d 0d 7d |turn(res|ult);..}|
|000006f0| 0d 0d 2f 2f 20 43 6f 70 | 79 20 61 20 6d 61 73 6b |..// Cop|y a mask|
|00000700| 2e 20 20 41 20 6d 61 73 | 6b 20 77 6f 75 6c 64 20 |. A mas|k would |
|00000710| 62 65 20 65 69 74 68 65 | 72 20 61 20 62 72 65 61 |be eithe|r a brea|
|00000720| 6b 20 6f 72 20 61 20 54 | 72 61 63 65 50 6f 69 6e |k or a T|racePoin|
|00000730| 74 73 20 6d 61 73 6b 2e | 0d 76 6f 69 64 20 44 6f |ts mask.|.void Do|
|00000740| 43 6f 70 79 4d 61 73 6b | 28 4d 61 73 6b 54 79 70 |CopyMask|(MaskTyp|
|00000750| 65 20 73 72 63 2c 4d 61 | 73 6b 54 79 70 65 20 64 |e src,Ma|skType d|
|00000760| 73 74 29 0d 7b 0d 09 42 | 6c 6f 63 6b 4d 6f 76 65 |st).{..B|lockMove|
|00000770| 28 28 50 74 72 29 73 72 | 63 2c 28 50 74 72 29 64 |((Ptr)sr|c,(Ptr)d|
|00000780| 73 74 2c 73 69 7a 65 6f | 66 28 4d 61 73 6b 54 79 |st,sizeo|f(MaskTy|
|00000790| 70 65 29 29 3b 0d 7d 0d | 0d 0d 73 6e 75 6d 20 44 |pe));.}.|..snum D|
|000007a0| 69 73 61 62 6c 65 54 72 | 61 63 65 42 75 66 66 65 |isableTr|aceBuffe|
|000007b0| 72 28 54 72 61 63 65 47 | 6c 6f 62 61 6c 73 20 2a |r(TraceG|lobals *|
|000007c0| 67 6c 6f 62 61 6c 73 29 | 0d 09 7b 0d 09 72 65 67 |globals)|..{..reg|
|000007d0| 69 73 74 65 72 20 73 68 | 6f 72 74 20 72 65 73 75 |ister sh|ort resu|
|000007e0| 6c 74 3b 0d 0d 09 69 66 | 20 28 20 21 20 67 6c 6f |lt;...if| ( ! glo|
|000007f0| 62 61 6c 73 2d 3e 66 42 | 75 66 66 65 72 45 6e 61 |bals->fB|ufferEna|
|00000800| 62 6c 65 64 29 0d 09 09 | 72 65 73 75 6c 74 20 3d |bled)...|result =|
|00000810| 20 66 6e 4f 70 6e 45 72 | 72 3b 20 2f 2f 20 22 46 | fnOpnEr|r; // "F|
|00000820| 69 6c 65 20 6e 6f 74 20 | 6f 70 65 6e 22 20 6d 65 |ile not |open" me|
|00000830| 61 6e 73 20 74 72 61 63 | 65 20 69 73 20 6e 6f 74 |ans trac|e is not|
|00000840| 20 65 6e 61 62 6c 65 64 | 0d 09 65 6c 73 65 0d 09 | enabled|..else..|
|00000850| 09 7b 0d 09 09 72 65 73 | 75 6c 74 20 3d 20 6e 6f |.{...res|ult = no|
|00000860| 45 72 72 3b 0d 09 09 67 | 6c 6f 62 61 6c 73 2d 3e |Err;...g|lobals->|
|00000870| 66 42 75 66 66 65 72 45 | 6e 61 62 6c 65 64 20 3d |fBufferE|nabled =|
|00000880| 20 66 61 6c 73 65 3b 0d | 09 09 44 69 73 70 6f 73 | false;.|..Dispos|
|00000890| 50 74 72 28 67 6c 6f 62 | 61 6c 73 2d 3e 66 42 75 |Ptr(glob|als->fBu|
|000008a0| 66 66 53 74 61 72 74 50 | 74 72 29 3b 0d 09 09 7d |ffStartP|tr);...}|
|000008b0| 0d 09 09 0d 09 72 65 74 | 75 72 6e 28 72 65 73 75 |.....ret|urn(resu|
|000008c0| 6c 74 29 3b 0d 09 0d 09 | 7d 0d 0d 73 6e 75 6d 20 |lt);....|}..snum |
|000008d0| 44 69 73 61 62 6c 65 54 | 72 61 63 65 46 69 6c 65 |DisableT|raceFile|
|000008e0| 28 54 72 61 63 65 47 6c | 6f 62 61 6c 73 20 2a 67 |(TraceGl|obals *g|
|000008f0| 6c 6f 62 61 6c 73 29 0d | 09 7b 0d 09 72 65 67 69 |lobals).|.{..regi|
|00000900| 73 74 65 72 20 73 6e 75 | 6d 20 72 65 73 75 6c 74 |ster snu|m result|
|00000910| 3b 0d 09 0d 09 69 66 20 | 28 20 21 20 67 6c 6f 62 |;....if |( ! glob|
|00000920| 61 6c 73 2d 3e 66 46 69 | 6c 65 45 6e 61 62 6c 65 |als->fFi|leEnable|
|00000930| 64 29 0d 09 09 72 65 73 | 75 6c 74 20 3d 20 76 6f |d)...res|ult = vo|
|00000940| 6c 4f 66 66 4c 69 6e 45 | 72 72 3b 20 2f 2f 20 22 |lOffLinE|rr; // "|
|00000950| 76 6f 6c 75 6d 65 20 6f | 66 66 6c 69 6e 65 22 20 |volume o|ffline" |
|00000960| 6d 65 61 6e 73 20 61 6c | 72 65 61 64 79 20 64 69 |means al|ready di|
|00000970| 73 61 62 6c 65 64 0d 09 | 65 6c 73 65 0d 09 09 7b |sabled..|else...{|
|00000980| 0d 09 09 09 67 6c 6f 62 | 61 6c 73 2d 3e 66 46 69 |....glob|als->fFi|
|00000990| 6c 65 45 6e 61 62 6c 65 | 64 20 3d 20 66 61 6c 73 |leEnable|d = fals|
|000009a0| 65 3b 0d 09 09 09 2f 2f | 20 28 76 6f 69 64 29 20 |e;....//| (void) |
|000009b0| 52 73 74 46 4c 6f 63 6b | 28 67 6c 6f 62 61 6c 73 |RstFLock|(globals|
|000009c0| 2d 3e 66 54 72 61 63 65 | 46 69 6c 65 4e 61 6d 65 |->fTrace|FileName|
|000009d0| 2c 20 67 6c 6f 62 61 6c | 73 2d 3e 66 56 52 65 66 |, global|s->fVRef|
|000009e0| 4e 75 6d 29 3b 0d 09 09 | 09 72 65 73 75 6c 74 20 |Num);...|.result |
|000009f0| 3d 20 6e 6f 45 72 72 3b | 0d 09 09 7d 0d 09 09 0d |= noErr;|...}....|
|00000a00| 09 72 65 74 75 72 6e 28 | 72 65 73 75 6c 74 29 3b |.return(|result);|
|00000a10| 0d 09 0d 09 7d 0d 0d 73 | 6e 75 6d 20 45 6e 61 62 |....}..s|num Enab|
|00000a20| 6c 65 54 72 61 63 65 42 | 75 66 66 65 72 28 54 72 |leTraceB|uffer(Tr|
|00000a30| 61 63 65 47 6c 6f 62 61 | 6c 73 20 2a 67 6c 6f 62 |aceGloba|ls *glob|
|00000a40| 61 6c 73 2c 20 54 72 61 | 63 65 50 61 72 61 6d 42 |als, Tra|ceParamB|
|00000a50| 6c 6f 63 6b 20 2a 70 61 | 72 61 6d 50 74 72 29 0d |lock *pa|ramPtr).|
|00000a60| 7b 0d 72 65 67 69 73 74 | 65 72 20 73 68 6f 72 74 |{.regist|er short|
|00000a70| 20 72 65 73 75 6c 74 3b | 0d 72 65 67 69 73 74 65 | result;|.registe|
|00000a80| 72 20 50 74 72 20 62 75 | 66 66 65 72 50 74 72 3b |r Ptr bu|fferPtr;|
|00000a90| 0d 72 65 67 69 73 74 65 | 72 20 6c 68 65 78 20 74 |.registe|r lhex t|
|00000aa0| 72 61 63 65 42 75 66 66 | 53 69 7a 65 3b 0d 72 65 |raceBuff|Size;.re|
|00000ab0| 67 69 73 74 65 72 20 73 | 68 65 78 20 6d 61 78 52 |gister s|hex maxR|
|00000ac0| 65 63 6f 72 64 53 69 7a | 65 3b 0d 0d 09 69 66 20 |ecordSiz|e;...if |
|00000ad0| 28 67 6c 6f 62 61 6c 73 | 2d 3e 66 42 75 66 66 65 |(globals|->fBuffe|
|00000ae0| 72 45 6e 61 62 6c 65 64 | 29 0d 09 09 72 65 73 75 |rEnabled|)...resu|
|00000af0| 6c 74 20 3d 20 66 42 73 | 79 45 72 72 3b 20 2f 2f |lt = fBs|yErr; //|
|00000b00| 20 22 46 69 6c 65 20 69 | 73 20 62 75 73 79 22 20 | "File i|s busy" |
|00000b10| 6d 65 61 6e 73 20 74 72 | 61 63 65 20 61 6c 72 65 |means tr|ace alre|
|00000b20| 61 64 79 20 65 6e 61 62 | 6c 65 64 20 2d 34 37 0d |ady enab|led -47.|
|00000b30| 09 65 6c 73 65 0d 09 09 | 7b 0d 09 09 2f 2f 20 4d |.else...|{...// M|
|00000b40| 61 6b 65 20 73 75 72 65 | 20 74 68 65 20 62 75 66 |ake sure| the buf|
|00000b50| 66 65 72 20 73 69 7a 65 | 20 69 73 20 65 76 65 6e |fer size| is even|
|00000b60| 3a 0d 09 0d 09 09 74 72 | 61 63 65 42 75 66 66 53 |:.....tr|aceBuffS|
|00000b70| 69 7a 65 20 3d 20 70 61 | 72 61 6d 50 74 72 2d 3e |ize = pa|ramPtr->|
|00000b80| 75 2e 65 6e 61 62 6c 65 | 2e 74 72 61 63 65 42 75 |u.enable|.traceBu|
|00000b90| 66 66 53 69 7a 65 3b 0d | 09 09 69 66 20 28 74 72 |ffSize;.|..if (tr|
|00000ba0| 61 63 65 42 75 66 66 53 | 69 7a 65 20 26 20 31 29 |aceBuffS|ize & 1)|
|00000bb0| 0d 09 09 09 74 72 61 63 | 65 42 75 66 66 53 69 7a |....trac|eBuffSiz|
|00000bc0| 65 2d 2d 3b 0d 09 09 0d | 09 09 2f 2f 20 41 6c 6c |e--;....|..// All|
|00000bd0| 6f 63 61 74 65 20 74 68 | 65 20 74 72 61 63 65 20 |ocate th|e trace |
|00000be0| 62 75 66 66 65 72 20 28 | 6f 6e 20 74 68 65 20 53 |buffer (|on the S|
|00000bf0| 79 73 74 65 6d 20 48 65 | 61 70 29 0d 0d 09 09 62 |ystem He|ap)....b|
|00000c00| 75 66 66 65 72 50 74 72 | 20 3d 20 4e 65 77 50 74 |ufferPtr| = NewPt|
|00000c10| 72 53 79 73 28 74 72 61 | 63 65 42 75 66 66 53 69 |rSys(tra|ceBuffSi|
|00000c20| 7a 65 29 3b 0d 0d 09 09 | 69 66 20 28 62 75 66 66 |ze);....|if (buff|
|00000c30| 65 72 50 74 72 20 3d 3d | 20 6e 69 6c 29 0d 09 09 |erPtr ==| nil)...|
|00000c40| 09 7b 0d 09 09 09 72 65 | 73 75 6c 74 20 3d 20 4d |.{....re|sult = M|
|00000c50| 65 6d 45 72 72 6f 72 28 | 29 3b 0d 09 09 09 7d 0d |emError(|);....}.|
|00000c60| 09 09 09 0d 09 09 65 6c | 73 65 0d 09 09 09 7b 0d |......el|se....{.|
|00000c70| 09 09 09 0d 09 09 09 72 | 65 73 75 6c 74 20 3d 20 |.......r|esult = |
|00000c80| 6e 6f 45 72 72 3b 0d 09 | 09 09 0d 09 09 09 67 6c |noErr;..|......gl|
|00000c90| 6f 62 61 6c 73 2d 3e 66 | 42 75 66 66 65 72 45 6e |obals->f|BufferEn|
|00000ca0| 61 62 6c 65 64 20 3d 20 | 74 72 75 65 3b 0d 09 09 |abled = |true;...|
|00000cb0| 09 67 6c 6f 62 61 6c 73 | 2d 3e 66 4c 6f 63 6b 65 |.globals|->fLocke|
|00000cc0| 64 4f 75 74 46 6c 61 67 | 20 3d 20 66 61 6c 73 65 |dOutFlag| = false|
|00000cd0| 3b 09 2f 2f 20 72 65 73 | 65 74 20 6c 6f 63 6b 65 |;.// res|et locke|
|00000ce0| 64 2d 6f 75 74 20 66 6c | 61 67 0d 09 09 09 09 09 |d-out fl|ag......|
|00000cf0| 09 0d 09 09 09 2f 2f 20 | 69 6e 69 74 69 61 6c 69 |.....// |initiali|
|00000d00| 7a 65 20 62 75 66 66 65 | 72 20 63 6f 6e 74 72 6f |ze buffe|r contro|
|00000d10| 6c 20 66 69 65 6c 64 73 | 20 3a 0d 09 0d 09 09 09 |l fields| :......|
|00000d20| 67 6c 6f 62 61 6c 73 2d | 3e 66 54 72 61 63 65 42 |globals-|>fTraceB|
|00000d30| 75 66 66 53 69 7a 65 20 | 3d 20 74 72 61 63 65 42 |uffSize |= traceB|
|00000d40| 75 66 66 53 69 7a 65 3b | 0d 09 09 09 67 6c 6f 62 |uffSize;|....glob|
|00000d50| 61 6c 73 2d 3e 66 54 72 | 61 63 65 42 75 66 66 53 |als->fTr|aceBuffS|
|00000d60| 69 7a 65 49 6e 64 65 78 | 20 3d 20 70 61 72 61 6d |izeIndex| = param|
|00000d70| 50 74 72 2d 3e 75 2e 65 | 6e 61 62 6c 65 2e 74 72 |Ptr->u.e|nable.tr|
|00000d80| 61 63 65 42 75 66 66 53 | 69 7a 65 49 6e 64 65 78 |aceBuffS|izeIndex|
|00000d90| 3b 0d 09 09 09 67 6c 6f | 62 61 6c 73 2d 3e 66 42 |;....glo|bals->fB|
|00000da0| 75 66 66 53 74 61 72 74 | 50 74 72 20 3d 20 62 75 |uffStart|Ptr = bu|
|00000db0| 66 66 65 72 50 74 72 3b | 0d 09 09 09 67 6c 6f 62 |fferPtr;|....glob|
|00000dc0| 61 6c 73 2d 3e 66 42 75 | 66 66 45 6e 64 50 74 72 |als->fBu|ffEndPtr|
|00000dd0| 20 3d 20 62 75 66 66 65 | 72 50 74 72 20 2b 20 28 | = buffe|rPtr + (|
|00000de0| 74 72 61 63 65 42 75 66 | 66 53 69 7a 65 20 2d 20 |traceBuf|fSize - |
|00000df0| 31 29 3b 0d 09 09 09 67 | 6c 6f 62 61 6c 73 2d 3e |1);....g|lobals->|
|00000e00| 66 4e 65 78 74 52 65 61 | 64 50 74 72 20 3d 20 62 |fNextRea|dPtr = b|
|00000e10| 75 66 66 65 72 50 74 72 | 3b 0d 09 09 09 67 6c 6f |ufferPtr|;....glo|
|00000e20| 62 61 6c 73 2d 3e 66 4e | 65 78 74 57 72 69 74 65 |bals->fN|extWrite|
|00000e30| 50 74 72 20 3d 20 62 75 | 66 66 65 72 50 74 72 3b |Ptr = bu|fferPtr;|
|00000e40| 0d 09 0d 09 09 09 2f 2f | 20 4d 61 78 69 6d 75 6d |......//| Maximum|
|00000e50| 20 73 69 7a 65 20 64 61 | 74 61 20 72 65 63 6f 72 | size da|ta recor|
|00000e60| 64 20 6d 75 73 74 20 6c | 65 61 76 65 20 72 6f 6f |d must l|eave roo|
|00000e70| 6d 20 66 6f 72 20 61 74 | 20 6c 65 61 73 74 20 6f |m for at| least o|
|00000e80| 6e 65 0d 09 09 09 2f 2f | 20 4c 6f 73 74 2d 44 61 |ne....//| Lost-Da|
|00000e90| 74 61 20 72 65 63 6f 72 | 64 20 61 6e 64 20 6f 6e |ta recor|d and on|
|00000ea0| 65 20 65 78 74 72 61 20 | 66 72 65 65 20 62 79 74 |e extra |free byt|
|00000eb0| 65 20 69 6e 20 74 68 65 | 20 62 75 66 66 65 72 0d |e in the| buffer.|
|00000ec0| 09 0d 09 09 09 6d 61 78 | 52 65 63 6f 72 64 53 69 |.....max|RecordSi|
|00000ed0| 7a 65 20 3d 20 28 74 72 | 61 63 65 42 75 66 66 53 |ze = (tr|aceBuffS|
|00000ee0| 69 7a 65 20 2d 20 73 69 | 7a 65 6f 66 28 4e 65 77 |ize - si|zeof(New|
|00000ef0| 52 65 63 6f 72 64 54 65 | 6d 70 6c 61 74 65 29 29 |RecordTe|mplate))|
|00000f00| 20 2d 20 31 3b 0d 09 09 | 09 67 6c 6f 62 61 6c 73 | - 1;...|.globals|
|00000f10| 2d 3e 66 4d 61 78 52 65 | 63 6f 72 64 53 69 7a 65 |->fMaxRe|cordSize|
|00000f20| 20 3d 20 6d 61 78 52 65 | 63 6f 72 64 53 69 7a 65 | = maxRe|cordSize|
|00000f30| 3b 0d 0d 09 09 09 7d 0d | 09 09 7d 0d 09 09 0d 09 |;.....}.|..}.....|
|00000f40| 72 65 74 75 72 6e 28 72 | 65 73 75 6c 74 29 3b 0d |return(r|esult);.|
|00000f50| 09 0d 09 7d 0d 73 6e 75 | 6d 20 53 65 74 54 72 61 |...}.snu|m SetTra|
|00000f60| 63 65 46 69 6c 65 4e 61 | 6d 65 28 54 72 61 63 65 |ceFileNa|me(Trace|
|00000f70| 47 6c 6f 62 61 6c 73 20 | 2a 67 6c 6f 62 61 6c 73 |Globals |*globals|
|00000f80| 2c 20 54 72 61 63 65 50 | 61 72 61 6d 42 6c 6f 63 |, TraceP|aramBloc|
|00000f90| 6b 20 2a 70 61 72 61 6d | 50 74 72 29 0d 7b 0d 72 |k *param|Ptr).{.r|
|00000fa0| 65 67 69 73 74 65 72 20 | 73 6e 75 6d 20 09 72 65 |egister |snum .re|
|00000fb0| 73 75 6c 74 3b 0d 72 65 | 67 69 73 74 65 72 20 50 |sult;.re|gister P|
|00000fc0| 74 72 20 09 66 69 6c 65 | 4e 61 6d 65 3b 0d 72 65 |tr .file|Name;.re|
|00000fd0| 67 69 73 74 65 72 20 63 | 68 65 78 20 09 73 74 72 |gister c|hex .str|
|00000fe0| 6c 65 6e 3b 20 2f 2f 20 | 75 6e 73 69 67 6e 65 64 |len; // |unsigned|
|00000ff0| 21 0d 46 49 6e 66 6f 20 | 09 66 69 6e 64 65 72 49 |!.FInfo |.finderI|
|00001000| 6e 66 6f 3b 0d 6c 6f 6e | 67 20 09 66 69 6c 65 4c |nfo;.lon|g .fileL|
|00001010| 65 6e 67 74 68 20 3d 20 | 30 3b 0d 0d 2f 2f 73 61 |ength = |0;..//sa|
|00001020| 76 65 54 79 70 65 48 61 | 6e 64 6c 65 09 68 53 61 |veTypeHa|ndle.hSa|
|00001030| 76 65 3b 0d 2f 2f 73 68 | 6f 72 74 09 50 72 65 66 |ve;.//sh|ort.Pref|
|00001040| 73 52 65 73 52 65 66 4e | 75 6d 3b 0d 0d 09 28 76 |sResRefN|um;...(v|
|00001050| 6f 69 64 29 20 43 6c 6f | 73 65 54 72 61 63 65 46 |oid) Clo|seTraceF|
|00001060| 69 6c 65 28 67 6c 6f 62 | 61 6c 73 29 3b 09 2f 2a |ile(glob|als);./*|
|00001070| 20 43 6c 6f 73 65 20 6f | 75 74 20 61 6e 79 20 6f | Close o|ut any o|
|00001080| 6c 64 20 66 69 6c 65 2e | 2e 2e 20 20 2a 2f 0d 09 |ld file.|.. */..|
|00001090| 2f 2f 20 28 76 6f 69 64 | 29 20 52 73 74 46 4c 6f |// (void|) RstFLo|
|000010a0| 63 6b 28 67 6c 6f 62 61 | 6c 73 2d 3e 66 54 72 61 |ck(globa|ls->fTra|
|000010b0| 63 65 46 69 6c 65 4e 61 | 6d 65 2c 67 6c 6f 62 61 |ceFileNa|me,globa|
|000010c0| 6c 73 2d 3e 66 56 52 65 | 66 4e 75 6d 29 3b 09 2f |ls->fVRe|fNum);./|
|000010d0| 2a 20 41 6e 64 20 6c 65 | 74 20 74 68 65 6d 20 74 |* And le|t them t|
|000010e0| 72 61 73 68 20 69 74 20 | 2a 2f 0d 09 66 69 6c 65 |rash it |*/..file|
|000010f0| 4e 61 6d 65 20 3d 20 28 | 50 74 72 29 20 70 61 72 |Name = (|Ptr) par|
|00001100| 61 6d 50 74 72 2d 3e 75 | 2e 65 6e 61 62 6c 65 46 |amPtr->u|.enableF|
|00001110| 69 6c 65 2e 66 69 6c 65 | 4e 61 6d 65 3b 0d 09 72 |ile.file|Name;..r|
|00001120| 65 73 75 6c 74 20 3d 20 | 6e 6f 45 72 72 3b 0d 09 |esult = |noErr;..|
|00001130| 0d 09 69 66 20 28 67 6c | 6f 62 61 6c 73 2d 3e 66 |..if (gl|obals->f|
|00001140| 46 69 6c 65 45 6e 61 62 | 6c 65 64 20 26 26 20 30 |FileEnab|led && 0|
|00001150| 20 29 09 09 2f 2f 20 20 | 4e 4f 20 4c 4f 4e 47 45 | )..// |NO LONGE|
|00001160| 52 20 41 50 50 4c 49 45 | 53 20 0d 09 09 72 65 73 |R APPLIE|S ...res|
|00001170| 75 6c 74 20 3d 20 76 6f | 6c 4f 6e 4c 69 6e 45 72 |ult = vo|lOnLinEr|
|00001180| 72 3b 20 2f 2f 20 22 76 | 6f 6c 75 6d 65 20 61 6c |r; // "v|olume al|
|00001190| 72 65 61 64 79 20 6f 6e | 6c 69 6e 65 22 20 6d 65 |ready on|line" me|
|000011a0| 61 6e 73 20 61 6c 72 65 | 61 64 79 20 65 6e 61 62 |ans alre|ady enab|
|000011b0| 6c 65 64 0d 09 09 0d 09 | 65 6c 73 65 20 69 66 20 |led.....|else if |
|000011c0| 28 66 69 6c 65 4e 61 6d | 65 20 3d 3d 20 6e 69 6c |(fileNam|e == nil|
|000011d0| 29 0d 09 09 72 65 73 75 | 6c 74 20 3d 20 62 64 4e |)...resu|lt = bdN|
|000011e0| 61 6d 45 72 72 3b 20 2f | 2f 20 22 42 61 64 20 66 |amErr; /|/ "Bad f|
|000011f0| 69 6c 65 20 6e 61 6d 65 | 22 0d 09 65 6c 73 65 0d |ile name|"..else.|
|00001200| 09 09 7b 0d 0d 09 09 2f | 2f 20 56 6f 6c 75 6d 65 |..{..../|/ Volume|
|00001210| 20 72 65 66 6e 75 6d 20 | 69 73 20 70 61 73 73 65 | refnum |is passe|
|00001220| 64 20 61 6c 73 6f 3a 0d | 09 09 0d 09 09 67 6c 6f |d also:.|.....glo|
|00001230| 62 61 6c 73 2d 3e 66 56 | 52 65 66 4e 75 6d 20 3d |bals->fV|RefNum =|
|00001240| 20 70 61 72 61 6d 50 74 | 72 2d 3e 75 2e 65 6e 61 | paramPt|r->u.ena|
|00001250| 62 6c 65 46 69 6c 65 2e | 76 52 65 66 4e 75 6d 3b |bleFile.|vRefNum;|
|00001260| 0d 09 09 0d 09 09 2f 2f | 20 28 54 72 75 6e 63 61 |......//| (Trunca|
|00001270| 74 65 20 66 69 6c 65 20 | 6e 61 6d 65 20 69 66 20 |te file |name if |
|00001280| 74 6f 6f 20 6c 6f 6e 67 | 29 0d 09 09 0d 09 09 73 |too long|)......s|
|00001290| 74 72 6c 65 6e 20 3d 20 | 2a 66 69 6c 65 4e 61 6d |trlen = |*fileNam|
|000012a0| 65 20 2b 20 31 3b 0d 09 | 09 69 66 20 28 73 74 72 |e + 1;..|.if (str|
|000012b0| 6c 65 6e 20 3e 20 73 69 | 7a 65 6f 66 28 67 6c 6f |len > si|zeof(glo|
|000012c0| 62 61 6c 73 2d 3e 66 54 | 72 61 63 65 46 69 6c 65 |bals->fT|raceFile|
|000012d0| 4e 61 6d 65 29 29 0d 09 | 09 09 73 74 72 6c 65 6e |Name))..|..strlen|
|000012e0| 20 3d 20 73 69 7a 65 6f | 66 28 67 6c 6f 62 61 6c | = sizeo|f(global|
|000012f0| 73 2d 3e 66 54 72 61 63 | 65 46 69 6c 65 4e 61 6d |s->fTrac|eFileNam|
|00001300| 65 29 3b 0d 09 09 0d 09 | 09 2f 2f 20 43 6f 70 79 |e);.....|.// Copy|
|00001310| 20 74 68 65 20 66 69 6c | 65 20 6e 61 6d 65 3a 0d | the fil|e name:.|
|00001320| 0d 09 09 42 6c 6f 63 6b | 4d 6f 76 65 28 66 69 6c |...Block|Move(fil|
|00001330| 65 4e 61 6d 65 2c 20 67 | 6c 6f 62 61 6c 73 2d 3e |eName, g|lobals->|
|00001340| 66 54 72 61 63 65 46 69 | 6c 65 4e 61 6d 65 2c 20 |fTraceFi|leName, |
|00001350| 73 74 72 6c 65 6e 29 3b | 0d 09 09 67 6c 6f 62 61 |strlen);|...globa|
|00001360| 6c 73 2d 3e 66 54 72 61 | 63 65 46 69 6c 65 4e 61 |ls->fTra|ceFileNa|
|00001370| 6d 65 5b 30 5d 20 3d 20 | 73 74 72 6c 65 6e 20 2d |me[0] = |strlen -|
|00001380| 20 31 3b 20 2f 2f 20 28 | 69 6e 20 63 61 73 65 20 | 1; // (|in case |
|00001390| 77 65 20 74 72 75 6e 63 | 61 74 65 64 20 69 74 29 |we trunc|ated it)|
|000013a0| 0d 09 09 0d 09 09 2f 2f | 20 43 68 65 63 6b 20 69 |......//| Check i|
|000013b0| 66 20 74 68 65 20 66 69 | 6c 65 20 65 78 69 73 74 |f the fi|le exist|
|000013c0| 73 2c 20 61 6e 64 20 69 | 66 20 69 74 20 68 61 73 |s, and i|f it has|
|000013d0| 20 74 68 65 20 72 69 67 | 68 74 20 46 69 6e 64 65 | the rig|ht Finde|
|000013e0| 72 20 69 6e 66 6f 2e 2e | 0d 09 09 2f 2f 20 49 66 |r info..|...// If|
|000013f0| 20 69 74 20 64 6f 65 73 | 6e 27 74 20 65 78 69 73 | it does|n't exis|
|00001400| 74 2c 20 74 68 65 6e 20 | 63 72 65 61 74 65 20 69 |t, then |create i|
|00001410| 74 2e 0d 09 09 0d 09 09 | 72 65 73 75 6c 74 20 3d |t.......|result =|
|00001420| 20 47 65 74 46 49 6e 66 | 6f 28 67 6c 6f 62 61 6c | GetFInf|o(global|
|00001430| 73 2d 3e 66 54 72 61 63 | 65 46 69 6c 65 4e 61 6d |s->fTrac|eFileNam|
|00001440| 65 2c 20 67 6c 6f 62 61 | 6c 73 2d 3e 66 56 52 65 |e, globa|ls->fVRe|
|00001450| 66 4e 75 6d 2c 20 26 66 | 69 6e 64 65 72 49 6e 66 |fNum, &f|inderInf|
|00001460| 6f 29 3b 0d 0d 09 09 69 | 66 20 28 72 65 73 75 6c |o);....i|f (resul|
|00001470| 74 20 3d 3d 20 66 6e 66 | 45 72 72 29 09 2f 2f 20 |t == fnf|Err).// |
|00001480| 44 6f 65 73 6e 74 20 65 | 78 69 73 74 2c 20 63 72 |Doesnt e|xist, cr|
|00001490| 65 61 74 65 20 61 20 6e | 65 77 20 6f 6e 65 2e 2e |eate a n|ew one..|
|000014a0| 2e 20 0d 09 09 09 7b 0d | 09 09 09 09 72 65 73 75 |. ....{.|....resu|
|000014b0| 6c 74 20 3d 20 43 72 65 | 61 74 65 28 66 69 6c 65 |lt = Cre|ate(file|
|000014c0| 4e 61 6d 65 2c 20 67 6c | 6f 62 61 6c 73 2d 3e 66 |Name, gl|obals->f|
|000014d0| 56 52 65 66 4e 75 6d 2c | 20 67 6c 6f 62 61 6c 73 |VRefNum,| globals|
|000014e0| 2d 3e 66 4d 79 43 72 65 | 61 74 6f 72 2c 20 67 6c |->fMyCre|ator, gl|
|000014f0| 6f 62 61 6c 73 2d 3e 66 | 4d 79 46 69 6c 65 54 79 |obals->f|MyFileTy|
|00001500| 70 65 29 3b 0d 09 09 09 | 7d 0d 09 09 65 6c 73 65 |pe);....|}...else|
|00001510| 20 0d 09 09 69 66 20 28 | 72 65 73 75 6c 74 20 3d | ...if (|result =|
|00001520| 3d 20 6e 6f 45 72 72 29 | 0d 09 09 09 7b 0d 09 09 |= noErr)|....{...|
|00001530| 09 2f 2f 20 43 68 65 63 | 6b 20 66 69 6c 65 20 74 |.// Chec|k file t|
|00001540| 79 70 65 20 61 6e 64 20 | 63 72 65 61 74 6f 72 20 |ype and |creator |
|00001550| 28 69 74 20 6d 75 73 74 | 20 62 65 20 6f 75 72 73 |(it must| be ours|
|00001560| 29 3a 0d 09 09 09 69 66 | 20 28 20 28 66 69 6e 64 |):....if| ( (find|
|00001570| 65 72 49 6e 66 6f 2e 66 | 64 54 79 70 65 20 21 3d |erInfo.f|dType !=|
|00001580| 20 67 6c 6f 62 61 6c 73 | 2d 3e 66 4d 79 46 69 6c | globals|->fMyFil|
|00001590| 65 54 79 70 65 29 20 7c | 7c 0d 09 09 09 09 20 28 |eType) |||..... (|
|000015a0| 66 69 6e 64 65 72 49 6e | 66 6f 2e 66 64 43 72 65 |finderIn|fo.fdCre|
|000015b0| 61 74 6f 72 20 21 3d 20 | 67 6c 6f 62 61 6c 73 2d |ator != |globals-|
|000015c0| 3e 66 4d 79 43 72 65 61 | 74 6f 72 29 20 29 0d 09 |>fMyCrea|tor) )..|
|000015d0| 09 09 09 72 65 73 75 6c | 74 20 3d 20 65 78 74 46 |...resul|t = extF|
|000015e0| 53 45 72 72 3b 20 2f 2f | 20 22 45 78 74 65 72 6e |SErr; //| "Extern|
|000015f0| 61 6c 20 66 69 6c 65 20 | 73 79 73 74 65 6d 22 0d |al file |system".|
|00001600| 09 09 09 7d 0d 09 09 7d | 0d 09 0d 09 69 66 20 28 |...}...}|....if (|
|00001610| 72 65 73 75 6c 74 20 3d | 3d 20 6e 6f 45 72 72 29 |result =|= noErr)|
|00001620| 0d 09 09 7b 0d 09 09 09 | 28 76 6f 69 64 29 20 4f |...{....|(void) O|
|00001630| 70 65 6e 54 72 61 63 65 | 46 69 6c 65 28 67 6c 6f |penTrace|File(glo|
|00001640| 62 61 6c 73 29 3b 0d 09 | 09 09 69 66 20 28 72 65 |bals);..|..if (re|
|00001650| 73 75 6c 74 20 3d 3d 20 | 6e 6f 45 72 72 29 0d 09 |sult == |noErr)..|
|00001660| 09 09 09 7b 0d 09 09 09 | 09 09 28 76 6f 69 64 29 |...{....|..(void)|
|00001670| 20 47 65 74 45 4f 46 28 | 67 6c 6f 62 61 6c 73 2d | GetEOF(|globals-|
|00001680| 3e 66 46 69 6c 65 52 65 | 66 4e 75 6d 2c 26 66 69 |>fFileRe|fNum,&fi|
|00001690| 6c 65 4c 65 6e 67 74 68 | 29 3b 0d 09 09 09 09 7d |leLength|);.....}|
|000016a0| 0d 09 09 09 28 76 6f 69 | 64 29 43 6c 6f 73 65 54 |....(voi|d)CloseT|
|000016b0| 72 61 63 65 46 69 6c 65 | 28 67 6c 6f 62 61 6c 73 |raceFile|(globals|
|000016c0| 29 3b 0d 09 09 09 67 6c | 6f 62 61 6c 73 2d 3e 66 |);....gl|obals->f|
|000016d0| 46 69 6c 65 45 6e 61 62 | 6c 65 64 20 3d 20 74 72 |FileEnab|led = tr|
|000016e0| 75 65 3b 0d 09 09 09 67 | 6c 6f 62 61 6c 73 2d 3e |ue;....g|lobals->|
|000016f0| 66 42 79 74 65 73 57 72 | 69 74 74 65 6e 20 3d 20 |fBytesWr|itten = |
|00001700| 66 69 6c 65 4c 65 6e 67 | 74 68 3b 0d 09 09 09 2f |fileLeng|th;..../|
|00001710| 2f 20 28 76 6f 69 64 29 | 20 53 65 74 46 4c 6f 63 |/ (void)| SetFLoc|
|00001720| 6b 28 67 6c 6f 62 61 6c | 73 2d 3e 66 54 72 61 63 |k(global|s->fTrac|
|00001730| 65 46 69 6c 65 4e 61 6d | 65 2c 67 6c 6f 62 61 6c |eFileNam|e,global|
|00001740| 73 2d 3e 66 56 52 65 66 | 4e 75 6d 29 3b 09 2f 2f |s->fVRef|Num);.//|
|00001750| 20 6e 6f 20 74 72 61 73 | 68 0d 09 09 7d 0d 09 72 | no tras|h...}..r|
|00001760| 65 74 75 72 6e 28 72 65 | 73 75 6c 74 29 3b 0d 7d |eturn(re|sult);.}|
|00001770| 0d 0d 0d 73 6e 75 6d 20 | 47 65 74 42 75 66 66 65 |...snum |GetBuffe|
|00001780| 72 53 70 61 63 65 28 54 | 72 61 63 65 47 6c 6f 62 |rSpace(T|raceGlob|
|00001790| 61 6c 73 20 2a 67 6c 6f | 62 61 6c 73 2c 20 73 68 |als *glo|bals, sh|
|000017a0| 65 78 20 61 6d 6f 75 6e | 74 4f 66 53 70 61 63 65 |ex amoun|tOfSpace|
|000017b0| 2c 20 42 6f 6f 6c 65 61 | 6e 20 2a 64 61 74 61 4c |, Boolea|n *dataL|
|000017c0| 6f 73 74 29 0d 09 7b 0d | 09 73 6e 75 6d 20 72 65 |ost)..{.|.snum re|
|000017d0| 73 75 6c 74 3b 0d 09 72 | 65 67 69 73 74 65 72 20 |sult;..r|egister |
|000017e0| 73 68 65 78 20 72 65 63 | 6f 72 64 53 69 7a 65 3b |shex rec|ordSize;|
|000017f0| 0d 09 72 65 67 69 73 74 | 65 72 20 6c 68 65 78 20 |..regist|er lhex |
|00001800| 66 72 65 65 53 70 61 63 | 65 3b 0d 09 72 65 67 69 |freeSpac|e;..regi|
|00001810| 73 74 65 72 20 42 6f 6f | 6c 65 61 6e 20 64 61 74 |ster Boo|lean dat|
|00001820| 61 57 61 73 4c 6f 73 74 | 3b 0d 09 72 65 67 69 73 |aWasLost|;..regis|
|00001830| 74 65 72 20 6c 68 65 78 | 20 62 75 66 66 65 72 53 |ter lhex| bufferS|
|00001840| 69 7a 65 3b 0d 09 72 65 | 67 69 73 74 65 72 20 50 |ize;..re|gister P|
|00001850| 74 72 20 6e 65 78 74 52 | 65 61 64 3b 0d 09 72 65 |tr nextR|ead;..re|
|00001860| 67 69 73 74 65 72 20 50 | 74 72 20 6e 65 78 74 57 |gister P|tr nextW|
|00001870| 72 69 74 65 3b 0d 09 72 | 65 67 69 73 74 65 72 20 |rite;..r|egister |
|00001880| 50 74 72 20 62 75 66 66 | 45 6e 64 3b 0d 09 0d 09 |Ptr buff|End;....|
|00001890| 2f 2f 20 54 68 69 73 20 | 66 75 6e 63 74 69 6f 6e |// This |function|
|000018a0| 20 61 74 74 65 6d 70 74 | 73 20 74 6f 20 63 6c 65 | attempt|s to cle|
|000018b0| 61 72 20 74 68 65 20 72 | 65 71 75 65 73 74 65 64 |ar the r|equested|
|000018c0| 20 61 6d 6f 75 6e 74 20 | 6f 66 20 73 70 61 63 65 | amount |of space|
|000018d0| 0d 09 2f 2f 20 69 6e 20 | 74 68 65 20 63 69 72 63 |..// in |the circ|
|000018e0| 75 6c 61 72 20 62 75 66 | 66 65 72 2c 20 74 68 72 |ular buf|fer, thr|
|000018f0| 6f 77 69 6e 67 20 6f 75 | 74 20 6f 6c 64 65 72 20 |owing ou|t older |
|00001900| 72 65 63 6f 72 64 73 20 | 69 66 20 6e 65 65 64 65 |records |if neede|
|00001910| 64 2e 0d 09 2f 2f 20 49 | 66 20 64 61 74 61 20 69 |d...// I|f data i|
|00001920| 73 20 74 68 72 6f 77 6e | 20 6f 75 74 2c 20 74 72 |s thrown| out, tr|
|00001930| 75 65 20 69 73 20 72 65 | 74 75 72 6e 65 64 20 69 |ue is re|turned i|
|00001940| 6e 20 27 42 6f 6f 6c 65 | 61 6e 20 2a 64 61 74 61 |n 'Boole|an *data|
|00001950| 4c 6f 73 74 27 2e 0d 09 | 2f 2f 20 49 66 20 74 68 |Lost'...|// If th|
|00001960| 65 20 61 6d 6f 75 6e 74 | 20 72 65 71 75 65 73 74 |e amount| request|
|00001970| 65 64 20 65 78 63 65 65 | 64 73 20 74 68 65 20 6d |ed excee|ds the m|
|00001980| 61 78 69 6d 75 6d 20 61 | 6c 6c 6f 77 65 64 20 72 |aximum a|llowed r|
|00001990| 65 63 6f 72 64 20 73 69 | 7a 65 2c 0d 09 2f 2f 20 |ecord si|ze,..// |
|000019a0| 74 68 65 6e 20 74 68 65 | 20 66 75 6e 63 74 69 6f |then the| functio|
|000019b0| 6e 20 72 65 74 75 72 6e | 73 20 2d 31 20 77 69 74 |n return|s -1 wit|
|000019c0| 68 6f 75 74 20 74 6f 75 | 63 68 69 6e 67 20 74 68 |hout tou|ching th|
|000019d0| 65 20 62 75 66 66 65 72 | 2e 0d 09 2f 2f 20 28 4f |e buffer|...// (O|
|000019e0| 66 20 63 6f 75 72 73 65 | 20 69 66 20 74 68 65 72 |f course| if ther|
|000019f0| 65 20 69 73 20 70 6c 65 | 6e 74 79 20 6f 66 20 72 |e is ple|nty of r|
|00001a00| 6f 6f 6d 20 61 76 61 69 | 6c 61 62 6c 65 2c 20 74 |oom avai|lable, t|
|00001a10| 68 65 6e 20 6e 6f 20 6f | 6c 64 65 72 0d 09 2f 2f |hen no o|lder..//|
|00001a20| 20 72 65 63 6f 72 64 73 | 20 61 72 65 20 6c 6f 73 | records| are los|
|00001a30| 74 2e 29 0d 09 0d 09 69 | 66 20 28 61 6d 6f 75 6e |t.)....i|f (amoun|
|00001a40| 74 4f 66 53 70 61 63 65 | 20 3e 20 67 6c 6f 62 61 |tOfSpace| > globa|
|00001a50| 6c 73 2d 3e 66 4d 61 78 | 52 65 63 6f 72 64 53 69 |ls->fMax|RecordSi|
|00001a60| 7a 65 29 0d 09 09 72 65 | 73 75 6c 74 20 3d 20 2d |ze)...re|sult = -|
|00001a70| 31 3b 0d 09 65 6c 73 65 | 0d 09 09 7b 0d 09 09 72 |1;..else|...{...r|
|00001a80| 65 73 75 6c 74 20 3d 20 | 30 3b 0d 09 09 64 61 74 |esult = |0;...dat|
|00001a90| 61 57 61 73 4c 6f 73 74 | 20 3d 20 66 61 6c 73 65 |aWasLost| = false|
|00001aa0| 3b 0d 09 09 0d 09 09 2f | 2f 20 4d 6f 76 65 20 73 |;....../|/ Move s|
|00001ab0| 6f 6d 65 20 76 61 6c 75 | 65 73 20 69 6e 74 6f 20 |ome valu|es into |
|00001ac0| 72 65 67 69 73 74 65 72 | 20 76 61 72 69 61 62 6c |register| variabl|
|00001ad0| 65 73 20 66 6f 72 20 6f | 70 74 69 6d 69 7a 61 74 |es for o|ptimizat|
|00001ae0| 69 6f 6e 3a 0d 09 09 0d | 09 09 6e 65 78 74 52 65 |ion:....|..nextRe|
|00001af0| 61 64 20 3d 20 67 6c 6f | 62 61 6c 73 2d 3e 66 4e |ad = glo|bals->fN|
|00001b00| 65 78 74 52 65 61 64 50 | 74 72 3b 0d 09 09 6e 65 |extReadP|tr;...ne|
|00001b10| 78 74 57 72 69 74 65 20 | 3d 20 67 6c 6f 62 61 6c |xtWrite |= global|
|00001b20| 73 2d 3e 66 4e 65 78 74 | 57 72 69 74 65 50 74 72 |s->fNext|WritePtr|
|00001b30| 3b 0d 09 09 62 75 66 66 | 45 6e 64 20 3d 20 67 6c |;...buff|End = gl|
|00001b40| 6f 62 61 6c 73 2d 3e 66 | 42 75 66 66 45 6e 64 50 |obals->f|BuffEndP|
|00001b50| 74 72 3b 0d 09 09 62 75 | 66 66 65 72 53 69 7a 65 |tr;...bu|fferSize|
|00001b60| 20 3d 20 67 6c 6f 62 61 | 6c 73 2d 3e 66 54 72 61 | = globa|ls->fTra|
|00001b70| 63 65 42 75 66 66 53 69 | 7a 65 3b 0d 09 09 0d 09 |ceBuffSi|ze;.....|
|00001b80| 09 2f 2f 20 4c 6f 6f 70 | 20 75 6e 74 69 6c 20 77 |.// Loop| until w|
|00001b90| 65 20 68 61 76 65 20 6f | 75 72 20 73 70 61 63 65 |e have o|ur space|
|00001ba0| 2e 2e 2e 0d 09 09 0d 09 | 09 66 72 65 65 53 70 61 |........|.freeSpa|
|00001bb0| 63 65 20 3d 20 30 3b 0d | 09 09 77 68 69 6c 65 20 |ce = 0;.|..while |
|00001bc0| 28 61 6d 6f 75 6e 74 4f | 66 53 70 61 63 65 20 3e |(amountO|fSpace >|
|00001bd0| 3d 20 66 72 65 65 53 70 | 61 63 65 29 0d 09 09 09 |= freeSp|ace)....|
|00001be0| 7b 0d 0d 09 09 09 2f 2f | 20 43 61 6c 63 75 6c 61 |{.....//| Calcula|
|00001bf0| 74 65 20 68 6f 77 20 6d | 75 63 68 20 66 72 65 65 |te how m|uch free|
|00001c00| 20 73 70 61 63 65 20 69 | 73 20 69 6e 20 74 68 65 | space i|s in the|
|00001c10| 20 62 75 66 66 65 72 2e | 20 20 49 66 20 74 68 65 | buffer.| If the|
|00001c20| 20 72 65 61 64 20 61 6e | 64 20 77 72 69 74 65 0d | read an|d write.|
|00001c30| 09 09 09 2f 2f 20 70 6f | 69 6e 74 65 72 73 20 61 |...// po|inters a|
|00001c40| 72 65 20 65 71 75 61 6c | 2c 20 74 68 65 6e 20 74 |re equal|, then t|
|00001c50| 68 65 20 62 75 66 66 65 | 72 20 69 73 20 65 6d 70 |he buffe|r is emp|
|00001c60| 74 79 2e 20 20 49 66 20 | 74 68 65 20 77 72 69 74 |ty. If |the writ|
|00001c70| 65 20 70 6f 69 6e 74 65 | 72 20 69 73 0d 09 09 09 |e pointe|r is....|
|00001c80| 2f 2f 20 6c 6f 77 65 72 | 20 74 68 61 6e 20 74 68 |// lower| than th|
|00001c90| 65 20 72 65 61 64 20 70 | 6f 69 6e 74 65 72 2c 20 |e read p|ointer, |
|00001ca0| 74 68 65 6e 20 74 68 65 | 20 66 72 65 65 20 73 70 |then the| free sp|
|00001cb0| 61 63 65 20 69 73 20 62 | 65 74 77 65 65 6e 20 74 |ace is b|etween t|
|00001cc0| 68 65 20 70 6f 69 6e 74 | 65 72 73 0d 09 09 09 2f |he point|ers..../|
|00001cd0| 2f 20 28 69 2e 65 2e 20 | 75 70 20 75 6e 74 69 6c |/ (i.e. |up until|
|00001ce0| 20 74 68 65 20 72 65 61 | 64 20 70 6f 69 6e 74 65 | the rea|d pointe|
|00001cf0| 72 20 69 73 20 72 65 61 | 63 68 65 64 29 2e 20 20 |r is rea|ched). |
|00001d00| 49 66 20 74 68 65 20 77 | 72 69 74 65 20 70 6f 69 |If the w|rite poi|
|00001d10| 6e 74 65 72 20 69 73 0d | 09 09 09 2f 2f 20 61 62 |nter is.|...// ab|
|00001d20| 6f 76 65 20 74 68 65 20 | 72 65 61 64 20 70 6f 69 |ove the |read poi|
|00001d30| 6e 74 65 72 2c 20 74 68 | 65 6e 20 74 68 65 20 66 |nter, th|en the f|
|00001d40| 72 65 65 20 73 70 61 63 | 65 20 69 73 20 66 72 6f |ree spac|e is fro|
|00001d50| 6d 20 74 68 65 20 77 72 | 69 74 65 20 70 6f 69 6e |m the wr|ite poin|
|00001d60| 74 65 72 20 74 6f 0d 09 | 09 09 2f 2f 20 74 68 65 |ter to..|..// the|
|00001d70| 20 65 6e 64 20 6f 66 20 | 74 68 65 20 62 75 66 66 | end of |the buff|
|00001d80| 65 72 2c 20 74 68 65 6e | 20 77 72 61 70 70 69 6e |er, then| wrappin|
|00001d90| 67 20 61 72 6f 75 6e 64 | 20 66 72 6f 6d 20 74 68 |g around| from th|
|00001da0| 65 20 73 74 61 72 74 20 | 6f 66 20 74 68 65 20 62 |e start |of the b|
|00001db0| 75 66 66 65 72 0d 09 09 | 09 2f 2f 20 75 70 20 74 |uffer...|.// up t|
|00001dc0| 6f 20 74 68 65 20 72 65 | 61 64 20 70 6f 69 6e 74 |o the re|ad point|
|00001dd0| 65 72 20 28 69 2e 65 2e | 20 74 68 65 20 73 70 61 |er (i.e.| the spa|
|00001de0| 63 65 20 62 65 74 77 65 | 65 6e 20 74 68 65 20 70 |ce betwe|en the p|
|00001df0| 6f 69 6e 74 65 72 73 20 | 63 6f 6e 74 61 69 6e 73 |ointers |contains|
|00001e00| 0d 09 09 09 2f 2f 20 75 | 6e 72 65 61 64 20 74 72 |....// u|nread tr|
|00001e10| 61 63 65 20 72 65 63 6f | 72 64 73 29 2e 0d 0d 09 |ace reco|rds)....|
|00001e20| 09 09 69 66 20 28 6e 65 | 78 74 57 72 69 74 65 20 |..if (ne|xtWrite |
|00001e30| 3d 3d 20 6e 65 78 74 52 | 65 61 64 29 20 09 09 09 |== nextR|ead) ...|
|00001e40| 09 2f 2f 20 52 45 41 44 | 3d 3d 57 52 49 54 45 20 |.// READ|==WRITE |
|00001e50| 6d 65 61 6e 73 20 65 6d | 70 74 79 20 62 75 66 66 |means em|pty buff|
|00001e60| 65 72 0d 09 09 09 09 66 | 72 65 65 53 70 61 63 65 |er.....f|reeSpace|
|00001e70| 20 3d 20 62 75 66 66 65 | 72 53 69 7a 65 3b 0d 09 | = buffe|rSize;..|
|00001e80| 09 09 65 6c 73 65 20 69 | 66 20 28 6e 65 78 74 57 |..else i|f (nextW|
|00001e90| 72 69 74 65 20 3c 20 6e | 65 78 74 52 65 61 64 29 |rite < n|extRead)|
|00001ea0| 0d 09 09 09 09 66 72 65 | 65 53 70 61 63 65 20 3d |.....fre|eSpace =|
|00001eb0| 20 6e 65 78 74 52 65 61 | 64 20 2d 20 6e 65 78 74 | nextRea|d - next|
|00001ec0| 57 72 69 74 65 3b 0d 09 | 09 09 65 6c 73 65 0d 09 |Write;..|..else..|
|00001ed0| 09 09 09 66 72 65 65 53 | 70 61 63 65 20 3d 20 62 |...freeS|pace = b|
|00001ee0| 75 66 66 65 72 53 69 7a | 65 20 2d 20 28 6e 65 78 |ufferSiz|e - (nex|
|00001ef0| 74 57 72 69 74 65 20 2d | 20 6e 65 78 74 52 65 61 |tWrite -| nextRea|
|00001f00| 64 29 3b 0d 0d 09 09 09 | 2f 2f 20 49 66 20 6e 6f |d);.....|// If no|
|00001f10| 74 20 65 6e 6f 75 67 68 | 20 66 72 65 65 20 73 70 |t enough| free sp|
|00001f20| 61 63 65 2c 20 74 6f 73 | 73 20 74 68 65 20 6f 6c |ace, tos|s the ol|
|00001f30| 64 65 73 74 20 72 65 63 | 6f 72 64 20 61 6e 64 20 |dest rec|ord and |
|00001f40| 74 72 79 20 61 67 61 69 | 6e 3a 0d 09 09 09 0d 09 |try agai|n:......|
|00001f50| 09 09 69 66 20 28 61 6d | 6f 75 6e 74 4f 66 53 70 |..if (am|ountOfSp|
|00001f60| 61 63 65 20 3e 3d 20 66 | 72 65 65 53 70 61 63 65 |ace >= f|reeSpace|
|00001f70| 29 0d 09 09 09 09 7b 0d | 09 09 09 09 0d 09 09 09 |).....{.|........|
|00001f80| 09 64 61 74 61 57 61 73 | 4c 6f 73 74 20 3d 20 74 |.dataWas|Lost = t|
|00001f90| 72 75 65 3b 0d 0d 09 09 | 09 09 2f 2f 20 72 65 74 |rue;....|..// ret|
|00001fa0| 72 69 65 76 65 20 74 68 | 65 20 4c 4c 20 66 69 65 |rieve th|e LL fie|
|00001fb0| 6c 64 20 3a 0d 09 09 09 | 09 2f 2f 20 28 32 20 62 |ld :....|.// (2 b|
|00001fc0| 79 74 65 20 6c 65 6e 67 | 74 68 20 66 69 65 6c 64 |yte leng|th field|
|00001fd0| 20 61 6c 77 61 79 73 20 | 66 61 6c 6c 73 20 6f 6e | always |falls on|
|00001fe0| 20 65 76 65 6e 20 6d 65 | 6d 6f 72 79 20 62 6f 75 | even me|mory bou|
|00001ff0| 6e 64 61 72 79 29 0d 09 | 09 09 09 0d 09 09 09 09 |ndary)..|........|
|00002000| 72 65 63 6f 72 64 53 69 | 7a 65 20 3d 20 2a 28 28 |recordSi|ze = *((|
|00002010| 73 68 65 78 20 2a 29 20 | 6e 65 78 74 52 65 61 64 |shex *) |nextRead|
|00002020| 29 3b 0d 0d 09 09 09 09 | 2f 2f 20 4d 6f 76 65 20 |);......|// Move |
|00002030| 74 68 65 20 72 65 61 64 | 20 70 6f 69 6e 74 65 72 |the read| pointer|
|00002040| 2c 20 77 72 61 70 70 69 | 6e 67 20 74 6f 20 73 74 |, wrappi|ng to st|
|00002050| 61 72 74 20 6f 66 20 62 | 75 66 66 65 72 20 69 73 |art of b|uffer is|
|00002060| 20 6e 65 65 64 65 64 3a | 0d 09 09 09 09 0d 09 09 | needed:|........|
|00002070| 09 09 6e 65 78 74 52 65 | 61 64 20 2b 3d 20 72 65 |..nextRe|ad += re|
|00002080| 63 6f 72 64 53 69 7a 65 | 3b 0d 09 09 09 09 0d 09 |cordSize|;.......|
|00002090| 09 09 09 69 66 20 28 6e | 65 78 74 52 65 61 64 20 |...if (n|extRead |
|000020a0| 3e 20 62 75 66 66 45 6e | 64 29 0d 09 09 09 09 09 |> buffEn|d)......|
|000020b0| 6e 65 78 74 52 65 61 64 | 20 3d 20 67 6c 6f 62 61 |nextRead| = globa|
|000020c0| 6c 73 2d 3e 66 42 75 66 | 66 53 74 61 72 74 50 74 |ls->fBuf|fStartPt|
|000020d0| 72 20 2b 20 28 6e 65 78 | 74 52 65 61 64 20 2d 20 |r + (nex|tRead - |
|000020e0| 62 75 66 66 45 6e 64 29 | 20 2d 20 31 3b 0d 0d 09 |buffEnd)| - 1;...|
|000020f0| 09 09 09 7d 0d 09 09 09 | 7d 0d 09 09 0d 09 09 2f |...}....|}....../|
|00002100| 2f 20 4d 6f 76 65 20 72 | 65 67 69 73 74 65 72 20 |/ Move r|egister |
|00002110| 76 61 72 69 61 62 6c 65 | 20 76 61 6c 75 65 20 62 |variable| value b|
|00002120| 61 63 6b 20 69 6e 74 6f | 20 67 6c 6f 62 61 6c 73 |ack into| globals|
|00002130| 20 69 6e 20 63 61 73 65 | 20 69 74 20 77 61 73 20 | in case| it was |
|00002140| 6d 6f 64 69 66 69 65 64 | 3a 0d 09 09 0d 09 09 67 |modified|:......g|
|00002150| 6c 6f 62 61 6c 73 2d 3e | 66 4e 65 78 74 52 65 61 |lobals->|fNextRea|
|00002160| 64 50 74 72 20 3d 20 6e | 65 78 74 52 65 61 64 3b |dPtr = n|extRead;|
|00002170| 0d 09 09 0d 09 09 2f 2f | 20 52 65 74 75 72 6e 20 |......//| Return |
|00002180| 6c 6f 73 74 20 64 61 74 | 61 20 69 6e 64 69 63 61 |lost dat|a indica|
|00002190| 74 69 6f 6e 3a 0d 09 09 | 0d 09 09 2a 64 61 74 61 |tion:...|...*data|
|000021a0| 4c 6f 73 74 20 3d 20 64 | 61 74 61 57 61 73 4c 6f |Lost = d|ataWasLo|
|000021b0| 73 74 3b 0d 09 09 0d 09 | 09 7d 0d 09 0d 09 72 65 |st;.....|.}....re|
|000021c0| 74 75 72 6e 28 72 65 73 | 75 6c 74 29 3b 0d 09 0d |turn(res|ult);...|
|000021d0| 7d 0d 0d 0d 2f 2a 0d 2a | 2a 09 53 65 74 20 6f 75 |}.../*.*|*.Set ou|
|000021e0| 72 20 67 6c 6f 61 62 61 | 6c 20 64 61 74 61 20 6d |r gloaba|l data m|
|000021f0| 61 73 6b 73 20 74 6f 20 | 74 68 65 20 6e 65 77 20 |asks to |the new |
|00002200| 6d 61 73 6b 20 74 68 61 | 74 20 77 65 20 67 65 74 |mask tha|t we get|
|00002210| 20 66 72 6f 6d 20 74 68 | 65 20 43 44 45 56 2e 2e | from th|e CDEV..|
|00002220| 2e 20 0d 2a 2f 0d 0d 73 | 6e 75 6d 20 47 65 74 4d |. .*/..s|num GetM|
|00002230| 61 73 6b 46 72 6f 6d 43 | 44 45 56 28 54 72 61 63 |askFromC|DEV(Trac|
|00002240| 65 47 6c 6f 62 61 6c 73 | 20 2a 67 6c 6f 62 61 6c |eGlobals| *global|
|00002250| 73 2c 20 54 72 61 63 65 | 50 61 72 61 6d 42 6c 6f |s, Trace|ParamBlo|
|00002260| 63 6b 20 2a 70 61 72 61 | 6d 50 74 72 2c 73 68 6f |ck *para|mPtr,sho|
|00002270| 72 74 20 63 73 43 6f 64 | 65 29 0d 7b 0d 09 69 66 |rt csCod|e).{..if|
|00002280| 20 28 63 73 43 6f 64 65 | 20 3d 3d 20 6b 47 65 74 | (csCode| == kGet|
|00002290| 43 64 65 76 42 72 65 61 | 6b 4d 61 73 6b 29 09 09 |CdevBrea|kMask)..|
|000022a0| 0d 09 09 44 6f 43 6f 70 | 79 4d 61 73 6b 28 70 61 |...DoCop|yMask(pa|
|000022b0| 72 61 6d 50 74 72 2d 3e | 75 2e 6d 61 73 6b 2e 4d |ramPtr->|u.mask.M|
|000022c0| 61 73 6b 2c 67 6c 6f 62 | 61 6c 73 2d 3e 66 42 72 |ask,glob|als->fBr|
|000022d0| 65 61 6b 4d 61 73 6b 29 | 3b 0d 09 65 6c 73 65 09 |eakMask)|;..else.|
|000022e0| 2f 2f 20 6b 47 65 74 43 | 64 65 76 54 72 61 63 65 |// kGetC|devTrace|
|000022f0| 4d 61 73 6b 20 62 79 20 | 64 65 66 61 75 6c 74 0d |Mask by |default.|
|00002300| 09 09 44 6f 43 6f 70 79 | 4d 61 73 6b 28 70 61 72 |..DoCopy|Mask(par|
|00002310| 61 6d 50 74 72 2d 3e 75 | 2e 6d 61 73 6b 2e 4d 61 |amPtr->u|.mask.Ma|
|00002320| 73 6b 2c 67 6c 6f 62 61 | 6c 73 2d 3e 66 54 72 61 |sk,globa|ls->fTra|
|00002330| 63 65 4d 61 73 6b 29 3b | 0d 09 67 6c 6f 62 61 6c |ceMask);|..global|
|00002340| 73 2d 3e 66 42 72 65 61 | 6b 4f 6e 63 65 54 68 65 |s->fBrea|kOnceThe|
|00002350| 6e 43 6c 65 61 72 20 3d | 20 70 61 72 61 6d 50 74 |nClear =| paramPt|
|00002360| 72 2d 3e 75 2e 6d 61 73 | 6b 2e 42 72 65 61 6b 4f |r->u.mas|k.BreakO|
|00002370| 6e 63 65 3b 0d 09 72 65 | 74 75 72 6e 28 6e 6f 45 |nce;..re|turn(noE|
|00002380| 72 72 29 3b 0d 7d 0d 0d | 0d 76 6f 69 64 20 47 65 |rr);.}..|.void Ge|
|00002390| 74 4e 65 77 52 65 63 6f | 72 64 28 54 72 61 63 65 |tNewReco|rd(Trace|
|000023a0| 47 6c 6f 62 61 6c 73 20 | 2a 67 6c 6f 62 61 6c 73 |Globals |*globals|
|000023b0| 2c 20 73 68 65 78 20 72 | 65 63 6f 72 64 53 69 7a |, shex r|ecordSiz|
|000023c0| 65 2c 20 50 74 72 20 2a | 72 65 63 6f 72 64 41 64 |e, Ptr *|recordAd|
|000023d0| 64 72 2c 0d 20 73 68 65 | 78 20 2a 73 70 6c 69 74 |dr,. she|x *split|
|000023e0| 53 69 7a 65 2c 20 50 74 | 72 20 2a 73 65 63 6f 6e |Size, Pt|r *secon|
|000023f0| 64 41 64 64 72 29 0d 09 | 7b 0d 09 73 6e 75 6d 20 |dAddr)..|{..snum |
|00002400| 72 65 73 75 6c 74 3b 0d | 09 42 6f 6f 6c 65 61 6e |result;.|.Boolean|
|00002410| 20 64 61 74 61 57 61 73 | 4c 6f 73 74 3b 0d 09 4e | dataWas|Lost;..N|
|00002420| 65 77 52 65 63 6f 72 64 | 54 65 6d 70 6c 61 74 65 |ewRecord|Template|
|00002430| 20 74 65 6d 70 6c 61 74 | 65 3b 09 09 09 2f 2f 20 | templat|e;...// |
|00002440| 55 73 65 64 20 74 6f 20 | 63 72 65 61 74 65 20 61 |Used to |create a|
|00002450| 20 6c 6f 73 74 2d 64 61 | 74 61 20 72 65 63 6f 72 | lost-da|ta recor|
|00002460| 64 0d 09 72 65 67 69 73 | 74 65 72 20 73 68 65 78 |d..regis|ter shex|
|00002470| 20 74 6f 70 53 69 7a 65 | 3b 0d 09 72 65 67 69 73 | topSize|;..regis|
|00002480| 74 65 72 20 73 68 65 78 | 20 73 65 63 6f 6e 64 50 |ter shex| secondP|
|00002490| 61 72 74 3b 0d 09 72 65 | 67 69 73 74 65 72 20 50 |art;..re|gister P|
|000024a0| 74 72 20 62 75 66 66 53 | 74 61 72 74 3b 0d 09 72 |tr buffS|tart;..r|
|000024b0| 65 67 69 73 74 65 72 20 | 50 74 72 20 62 75 66 66 |egister |Ptr buff|
|000024c0| 45 6e 64 3b 0d 09 72 65 | 67 69 73 74 65 72 20 50 |End;..re|gister P|
|000024d0| 74 72 20 6e 65 78 74 57 | 72 69 74 65 3b 0d 09 72 |tr nextW|rite;..r|
|000024e0| 65 67 69 73 74 65 72 20 | 50 74 72 20 6e 65 78 74 |egister |Ptr next|
|000024f0| 52 65 61 64 3b 0d 09 0d | 09 64 61 74 61 57 61 73 |Read;...|.dataWas|
|00002500| 4c 6f 73 74 20 3d 20 66 | 61 6c 73 65 3b 0d 09 0d |Lost = f|alse;...|
|00002510| 09 2f 2f 20 47 65 74 20 | 73 70 61 63 65 20 66 6f |.// Get |space fo|
|00002520| 72 20 74 68 65 20 6e 65 | 77 20 72 65 63 6f 72 64 |r the ne|w record|
|00002530| 3a 0d 09 2f 2f 20 54 6f | 20 69 6e 63 72 65 61 73 |:..// To| increas|
|00002540| 65 20 70 65 72 66 6f 72 | 6d 61 6e 63 65 2c 20 61 |e perfor|mance, a|
|00002550| 6c 77 61 79 73 20 61 73 | 6b 20 66 6f 72 20 65 6e |lways as|k for en|
|00002560| 6f 75 67 68 20 72 6f 6f | 6d 20 66 6f 72 20 74 68 |ough roo|m for th|
|00002570| 65 20 6e 65 77 20 72 65 | 63 6f 72 64 0d 09 2f 2f |e new re|cord..//|
|00002580| 20 70 6c 75 73 20 61 20 | 6c 6f 73 74 2d 64 61 74 | plus a |lost-dat|
|00002590| 61 20 72 65 63 6f 72 64 | 2e 20 20 41 6c 74 68 6f |a record|. Altho|
|000025a0| 75 67 68 20 74 68 65 20 | 65 78 74 72 61 20 72 6f |ugh the |extra ro|
|000025b0| 6f 6d 20 66 6f 72 20 74 | 68 65 20 6c 6f 73 74 2d |om for t|he lost-|
|000025c0| 64 61 74 61 20 72 65 63 | 6f 72 64 0d 09 2f 2f 20 |data rec|ord..// |
|000025d0| 6d 61 79 20 62 65 20 77 | 68 61 74 20 63 61 75 73 |may be w|hat caus|
|000025e0| 65 73 20 61 20 6c 6f 73 | 74 2d 64 61 74 61 20 63 |es a los|t-data c|
|000025f0| 6f 6e 64 69 74 69 6f 6e | 2c 20 69 6e 20 74 68 69 |ondition|, in thi|
|00002600| 73 20 63 61 73 65 20 74 | 68 65 20 62 75 66 66 65 |s case t|he buffe|
|00002610| 72 20 69 73 20 61 6c 6d | 6f 73 74 0d 09 2f 2f 20 |r is alm|ost..// |
|00002620| 66 75 6c 6c 20 61 6e 79 | 77 61 79 20 61 6e 64 20 |full any|way and |
|00002630| 77 65 20 61 72 65 20 62 | 6f 75 6e 64 20 74 6f 20 |we are b|ound to |
|00002640| 6c 6f 73 65 20 64 61 74 | 61 20 73 6f 6f 6e 20 61 |lose dat|a soon a|
|00002650| 6e 79 77 61 79 2e 20 20 | 49 6e 20 74 68 69 73 20 |nyway. |In this |
|00002660| 69 6d 70 6c 65 6d 65 6e | 74 61 74 69 6f 6e 2c 0d |implemen|tation,.|
|00002670| 09 2f 2f 20 77 65 20 77 | 69 6c 6c 20 73 61 63 72 |.// we w|ill sacr|
|00002680| 69 66 69 63 65 20 74 68 | 65 20 65 66 66 69 63 69 |ifice th|e effici|
|00002690| 65 6e 63 79 20 6f 66 20 | 74 68 65 20 62 75 66 66 |ency of |the buff|
|000026a0| 65 72 20 73 69 7a 65 20 | 69 6e 20 66 61 76 6f 72 |er size |in favor|
|000026b0| 20 6f 66 20 65 66 66 69 | 63 69 65 6e 63 79 0d 09 | of effi|ciency..|
|000026c0| 2f 2f 20 6f 66 20 65 78 | 65 63 75 74 69 6f 6e 20 |// of ex|ecution |
|000026d0| 28 61 66 74 65 72 20 61 | 6c 6c 2c 20 69 66 20 77 |(after a|ll, if w|
|000026e0| 65 20 61 72 65 20 6c 65 | 74 74 69 6e 67 20 74 68 |e are le|tting th|
|000026f0| 65 20 62 75 66 66 65 72 | 20 72 75 6e 20 66 75 6c |e buffer| run ful|
|00002700| 6c 20 77 69 74 68 6f 75 | 74 0d 09 2f 2f 20 72 65 |l withou|t..// re|
|00002710| 74 72 69 65 76 69 6e 67 | 20 61 6e 79 20 72 65 63 |trieving| any rec|
|00002720| 6f 72 64 73 2c 20 77 65 | 20 77 69 6c 6c 20 64 65 |ords, we| will de|
|00002730| 66 69 6e 69 74 65 6c 79 | 20 77 61 6e 74 20 74 68 |finitely| want th|
|00002740| 65 20 65 66 66 69 63 69 | 65 6e 63 79 29 2e 0d 09 |e effici|ency)...|
|00002750| 2f 2f 20 4e 4f 54 45 3a | 20 43 75 72 72 65 6e 74 |// NOTE:| Current|
|00002760| 6c 79 2c 20 69 66 20 47 | 65 74 42 75 66 66 65 72 |ly, if G|etBuffer|
|00002770| 53 70 61 63 65 20 72 65 | 74 75 72 6e 73 20 61 6e |Space re|turns an|
|00002780| 20 65 72 72 6f 72 2c 20 | 77 65 20 64 6f 6e 27 74 | error, |we don't|
|00002790| 20 64 6f 20 61 6e 79 74 | 68 69 6e 67 20 61 74 20 | do anyt|hing at |
|000027a0| 61 6c 6c 2e 0d 09 0d 09 | 72 65 73 75 6c 74 20 3d |all.....|result =|
|000027b0| 20 47 65 74 42 75 66 66 | 65 72 53 70 61 63 65 28 | GetBuff|erSpace(|
|000027c0| 67 6c 6f 62 61 6c 73 2c | 20 72 65 63 6f 72 64 53 |globals,| recordS|
|000027d0| 69 7a 65 20 2b 20 73 69 | 7a 65 6f 66 28 4e 65 77 |ize + si|zeof(New|
|000027e0| 52 65 63 6f 72 64 54 65 | 6d 70 6c 61 74 65 29 2c |RecordTe|mplate),|
|000027f0| 20 26 64 61 74 61 57 61 | 73 4c 6f 73 74 29 3b 0d | &dataWa|sLost);.|
|00002800| 09 0d 09 69 66 20 28 72 | 65 73 75 6c 74 20 3d 3d |...if (r|esult ==|
|00002810| 20 30 29 0d 09 09 7b 0d | 09 09 0d 09 09 2f 2f 20 | 0)...{.|.....// |
|00002820| 4d 6f 76 65 20 73 6f 6d | 65 20 76 61 6c 75 65 73 |Move som|e values|
|00002830| 20 69 6e 74 6f 20 72 65 | 67 69 73 74 65 72 20 76 | into re|gister v|
|00002840| 61 72 69 61 62 6c 65 73 | 20 66 6f 72 20 6f 70 74 |ariables| for opt|
|00002850| 69 6d 69 7a 61 74 69 6f | 6e 3a 0d 09 09 0d 09 09 |imizatio|n:......|
|00002860| 6e 65 78 74 57 72 69 74 | 65 20 3d 20 67 6c 6f 62 |nextWrit|e = glob|
|00002870| 61 6c 73 2d 3e 66 4e 65 | 78 74 57 72 69 74 65 50 |als->fNe|xtWriteP|
|00002880| 74 72 3b 0d 09 09 6e 65 | 78 74 52 65 61 64 20 3d |tr;...ne|xtRead =|
|00002890| 20 67 6c 6f 62 61 6c 73 | 2d 3e 66 4e 65 78 74 52 | globals|->fNextR|
|000028a0| 65 61 64 50 74 72 3b 0d | 09 09 62 75 66 66 53 74 |eadPtr;.|..buffSt|
|000028b0| 61 72 74 20 3d 20 67 6c | 6f 62 61 6c 73 2d 3e 66 |art = gl|obals->f|
|000028c0| 42 75 66 66 53 74 61 72 | 74 50 74 72 3b 0d 09 09 |BuffStar|tPtr;...|
|000028d0| 62 75 66 66 45 6e 64 20 | 3d 20 67 6c 6f 62 61 6c |buffEnd |= global|
|000028e0| 73 2d 3e 66 42 75 66 66 | 45 6e 64 50 74 72 3b 0d |s->fBuff|EndPtr;.|
|000028f0| 09 0d 09 09 2f 2f 20 49 | 66 20 64 61 74 61 20 77 |....// I|f data w|
|00002900| 61 73 20 6c 6f 73 74 20 | 77 68 69 6c 65 20 66 69 |as lost |while fi|
|00002910| 6e 64 69 6e 67 20 62 75 | 66 66 65 72 20 73 70 61 |nding bu|ffer spa|
|00002920| 63 65 2c 20 74 68 65 6e | 20 69 6e 73 65 72 74 20 |ce, then| insert |
|00002930| 61 20 6c 6f 73 74 2d 64 | 61 74 61 20 72 65 63 6f |a lost-d|ata reco|
|00002940| 72 64 3a 0d 09 09 2f 2f | 20 54 68 69 73 20 72 65 |rd:...//| This re|
|00002950| 63 6f 72 64 20 6d 75 73 | 74 20 62 65 20 69 6e 73 |cord mus|t be ins|
|00002960| 65 72 74 65 64 20 61 73 | 20 74 68 65 20 6e 65 78 |erted as| the nex|
|00002970| 74 20 72 65 61 64 20 28 | 69 6e 20 66 72 6f 6e 74 |t read (|in front|
|00002980| 20 6f 66 20 61 6c 6c 20 | 6f 74 68 65 72 20 72 65 | of all |other re|
|00002990| 63 6f 72 64 73 29 2e 0d | 09 09 0d 09 09 69 66 20 |cords)..|.....if |
|000029a0| 28 64 61 74 61 57 61 73 | 4c 6f 73 74 29 0d 09 09 |(dataWas|Lost)...|
|000029b0| 09 7b 0d 09 09 09 74 65 | 6d 70 6c 61 74 65 2e 6c |.{....te|mplate.l|
|000029c0| 65 6e 67 74 68 20 3d 20 | 73 69 7a 65 6f 66 28 4e |ength = |sizeof(N|
|000029d0| 65 77 52 65 63 6f 72 64 | 54 65 6d 70 6c 61 74 65 |ewRecord|Template|
|000029e0| 29 3b 0d 09 09 09 74 65 | 6d 70 6c 61 74 65 2e 64 |);....te|mplate.d|
|000029f0| 69 61 67 49 44 20 3d 20 | 6b 4c 6f 73 74 44 61 74 |iagID = |kLostDat|
|00002a00| 61 52 65 63 6f 72 64 3b | 0d 09 09 09 74 65 6d 70 |aRecord;|....temp|
|00002a10| 6c 61 74 65 2e 70 61 72 | 74 43 6f 64 65 20 3d 20 |late.par|tCode = |
|00002a20| 30 3b 0d 09 09 09 69 66 | 20 28 67 6c 6f 62 61 6c |0;....if| (global|
|00002a30| 73 2d 3e 66 54 69 6d 65 | 53 74 61 6d 70 54 79 70 |s->fTime|StampTyp|
|00002a40| 65 20 3d 3d 20 31 29 0d | 09 09 09 09 47 65 74 44 |e == 1).|....GetD|
|00002a50| 61 74 65 54 69 6d 65 28 | 26 74 65 6d 70 6c 61 74 |ateTime(|&templat|
|00002a60| 65 2e 74 69 6d 65 53 74 | 61 6d 70 29 3b 20 2f 2f |e.timeSt|amp); //|
|00002a70| 20 44 61 74 65 20 61 6e | 64 20 54 69 6d 65 20 74 | Date an|d Time t|
|00002a80| 69 6d 65 73 74 61 6d 70 | 0d 09 09 09 65 6c 73 65 |imestamp|....else|
|00002a90| 0d 09 09 09 09 74 65 6d | 70 6c 61 74 65 2e 74 69 |.....tem|plate.ti|
|00002aa0| 6d 65 53 74 61 6d 70 20 | 3d 20 54 69 63 6b 43 6f |meStamp |= TickCo|
|00002ab0| 75 6e 74 28 29 3b 20 2f | 2f 20 54 69 63 6b 73 20 |unt(); /|/ Ticks |
|00002ac0| 28 31 2f 36 30 20 73 65 | 63 29 20 74 69 6d 65 73 |(1/60 se|c) times|
|00002ad0| 74 61 6d 70 0d 09 09 09 | 74 65 6d 70 6c 61 74 65 |tamp....|template|
|00002ae0| 2e 74 69 6d 65 53 74 61 | 6d 70 54 79 70 65 20 3d |.timeSta|mpType =|
|00002af0| 20 67 6c 6f 62 61 6c 73 | 2d 3e 66 54 69 6d 65 53 | globals|->fTimeS|
|00002b00| 74 61 6d 70 54 79 70 65 | 3b 0d 09 09 09 74 65 6d |tampType|;....tem|
|00002b10| 70 6c 61 74 65 2e 66 6f | 72 6d 61 74 49 44 20 3d |plate.fo|rmatID =|
|00002b20| 20 30 78 30 30 3b 0d 0d | 09 09 09 73 65 63 6f 6e | 0x00;..|...secon|
|00002b30| 64 50 61 72 74 20 3d 20 | 6e 65 78 74 52 65 61 64 |dPart = |nextRead|
|00002b40| 20 2d 20 62 75 66 66 53 | 74 61 72 74 3b 0d 09 09 | - buffS|tart;...|
|00002b50| 09 69 66 20 28 73 65 63 | 6f 6e 64 50 61 72 74 20 |.if (sec|ondPart |
|00002b60| 3e 3d 20 73 69 7a 65 6f | 66 28 4e 65 77 52 65 63 |>= sizeo|f(NewRec|
|00002b70| 6f 72 64 54 65 6d 70 6c | 61 74 65 29 29 0d 09 09 |ordTempl|ate))...|
|00002b80| 09 09 7b 0d 09 09 09 09 | 2f 2f 20 49 74 20 77 69 |..{.....|// It wi|
|00002b90| 6c 6c 20 66 69 74 20 69 | 6e 20 6f 6e 65 20 70 69 |ll fit i|n one pi|
|00002ba0| 65 63 65 20 61 68 65 61 | 64 20 6f 66 20 6e 65 78 |ece ahea|d of nex|
|00002bb0| 74 20 72 65 61 64 20 72 | 65 63 6f 72 64 3a 0d 09 |t read r|ecord:..|
|00002bc0| 09 09 09 6e 65 78 74 52 | 65 61 64 20 2d 3d 20 73 |...nextR|ead -= s|
|00002bd0| 69 7a 65 6f 66 28 4e 65 | 77 52 65 63 6f 72 64 54 |izeof(Ne|wRecordT|
|00002be0| 65 6d 70 6c 61 74 65 29 | 3b 0d 09 09 09 09 42 6c |emplate)|;.....Bl|
|00002bf0| 6f 63 6b 4d 6f 76 65 28 | 28 50 74 72 29 20 26 74 |ockMove(|(Ptr) &t|
|00002c00| 65 6d 70 6c 61 74 65 2c | 20 6e 65 78 74 52 65 61 |emplate,| nextRea|
|00002c10| 64 2c 20 73 69 7a 65 6f | 66 28 4e 65 77 52 65 63 |d, sizeo|f(NewRec|
|00002c20| 6f 72 64 54 65 6d 70 6c | 61 74 65 29 29 3b 0d 09 |ordTempl|ate));..|
|00002c30| 09 09 09 7d 0d 09 09 09 | 65 6c 73 65 0d 09 09 09 |...}....|else....|
|00002c40| 09 7b 0d 09 09 09 09 2f | 2f 20 54 68 65 20 72 65 |.{...../|/ The re|
|00002c50| 63 6f 72 64 20 6d 75 73 | 74 20 62 65 20 73 70 6c |cord mus|t be spl|
|00002c60| 69 74 20 28 77 72 61 70 | 2d 61 72 6f 75 6e 64 20 |it (wrap|-around |
|00002c70| 62 61 63 6b 77 61 72 64 | 73 29 3a 0d 09 09 09 09 |backward|s):.....|
|00002c80| 74 6f 70 53 69 7a 65 20 | 3d 20 73 69 7a 65 6f 66 |topSize |= sizeof|
|00002c90| 28 4e 65 77 52 65 63 6f | 72 64 54 65 6d 70 6c 61 |(NewReco|rdTempla|
|00002ca0| 74 65 29 20 2d 20 73 65 | 63 6f 6e 64 50 61 72 74 |te) - se|condPart|
|00002cb0| 3b 0d 09 09 09 09 6e 65 | 78 74 52 65 61 64 20 3d |;.....ne|xtRead =|
|00002cc0| 20 28 62 75 66 66 45 6e | 64 20 2d 20 74 6f 70 53 | (buffEn|d - topS|
|00002cd0| 69 7a 65 29 20 2b 20 31 | 3b 0d 09 09 09 09 42 6c |ize) + 1|;.....Bl|
|00002ce0| 6f 63 6b 4d 6f 76 65 28 | 28 50 74 72 29 20 26 74 |ockMove(|(Ptr) &t|
|00002cf0| 65 6d 70 6c 61 74 65 2c | 20 6e 65 78 74 52 65 61 |emplate,| nextRea|
|00002d00| 64 2c 20 74 6f 70 53 69 | 7a 65 29 3b 0d 09 09 09 |d, topSi|ze);....|
|00002d10| 09 42 6c 6f 63 6b 4d 6f | 76 65 28 28 28 50 74 72 |.BlockMo|ve(((Ptr|
|00002d20| 29 20 26 74 65 6d 70 6c | 61 74 65 29 20 2b 20 73 |) &templ|ate) + s|
|00002d30| 65 63 6f 6e 64 50 61 72 | 74 2c 20 62 75 66 66 53 |econdPar|t, buffS|
|00002d40| 74 61 72 74 2c 20 73 65 | 63 6f 6e 64 50 61 72 74 |tart, se|condPart|
|00002d50| 29 3b 0d 09 09 09 09 7d | 0d 0d 09 09 09 2f 2f 20 |);.....}|.....// |
|00002d60| 4d 6f 76 65 20 74 68 65 | 20 72 65 67 69 73 74 65 |Move the| registe|
|00002d70| 72 20 63 6f 70 79 20 62 | 61 63 6b 20 69 6e 74 6f |r copy b|ack into|
|00002d80| 20 74 68 65 20 67 6c 6f | 62 61 6c 73 20 62 6c 6f | the glo|bals blo|
|00002d90| 63 6b 3a 0d 09 09 0d 09 | 09 09 67 6c 6f 62 61 6c |ck:.....|..global|
|00002da0| 73 2d 3e 66 4e 65 78 74 | 52 65 61 64 50 74 72 20 |s->fNext|ReadPtr |
|00002db0| 3d 20 6e 65 78 74 52 65 | 61 64 3b 0d 09 09 09 0d |= nextRe|ad;.....|
|00002dc0| 09 09 09 7d 0d 09 09 0d | 09 09 2f 2f 20 43 61 6c |...}....|..// Cal|
|00002dd0| 63 75 6c 61 74 65 20 74 | 68 65 20 72 65 74 75 72 |culate t|he retur|
|00002de0| 6e 20 76 61 6c 75 65 73 | 3a 0d 09 09 0d 09 09 2a |n values|:......*|
|00002df0| 72 65 63 6f 72 64 41 64 | 64 72 20 3d 20 6e 65 78 |recordAd|dr = nex|
|00002e00| 74 57 72 69 74 65 3b 09 | 09 09 2f 2f 20 74 68 69 |tWrite;.|..// thi|
|00002e10| 73 20 69 73 20 77 68 65 | 72 65 20 74 68 65 20 6e |s is whe|re the n|
|00002e20| 65 77 20 72 65 63 6f 72 | 64 20 67 6f 65 73 0d 09 |ew recor|d goes..|
|00002e30| 09 0d 09 09 74 6f 70 53 | 69 7a 65 20 3d 20 28 62 |....topS|ize = (b|
|00002e40| 75 66 66 45 6e 64 20 2d | 20 6e 65 78 74 57 72 69 |uffEnd -| nextWri|
|00002e50| 74 65 29 20 2b 20 31 3b | 0d 09 09 69 66 20 28 74 |te) + 1;|...if (t|
|00002e60| 6f 70 53 69 7a 65 20 3e | 3d 20 72 65 63 6f 72 64 |opSize >|= record|
|00002e70| 53 69 7a 65 29 0d 09 09 | 09 7b 0d 09 09 09 2a 73 |Size)...|.{....*s|
|00002e80| 70 6c 69 74 53 69 7a 65 | 20 3d 20 72 65 63 6f 72 |plitSize| = recor|
|00002e90| 64 53 69 7a 65 3b 09 09 | 2f 2f 20 49 66 20 77 65 |dSize;..|// If we|
|00002ea0| 20 63 61 6e 20 66 69 74 | 20 69 74 20 61 6c 6c 20 | can fit| it all |
|00002eb0| 62 65 66 6f 72 65 20 72 | 65 61 63 68 69 6e 67 20 |before r|eaching |
|00002ec0| 74 68 65 20 65 6e 64 2e | 2e 2e 0d 09 09 09 2a 73 |the end.|......*s|
|00002ed0| 65 63 6f 6e 64 41 64 64 | 72 20 3d 20 6e 69 6c 3b |econdAdd|r = nil;|
|00002ee0| 09 09 09 09 2f 2f 20 2e | 2e 2e 20 74 68 65 6e 20 |....// .|.. then |
|00002ef0| 74 68 65 72 65 20 69 73 | 20 6e 6f 20 73 65 63 6f |there is| no seco|
|00002f00| 6e 64 20 70 61 72 74 20 | 74 6f 20 74 68 65 20 72 |nd part |to the r|
|00002f10| 65 63 6f 72 64 0d 09 09 | 09 73 65 63 6f 6e 64 50 |ecord...|.secondP|
|00002f20| 61 72 74 20 3d 20 30 3b | 0d 09 09 09 7d 0d 09 09 |art = 0;|....}...|
|00002f30| 65 6c 73 65 0d 09 09 09 | 7b 0d 09 09 09 73 65 63 |else....|{....sec|
|00002f40| 6f 6e 64 50 61 72 74 20 | 3d 20 72 65 63 6f 72 64 |ondPart |= record|
|00002f50| 53 69 7a 65 20 2d 20 74 | 6f 70 53 69 7a 65 3b 0d |Size - t|opSize;.|
|00002f60| 09 09 09 2a 73 70 6c 69 | 74 53 69 7a 65 20 3d 20 |...*spli|tSize = |
|00002f70| 74 6f 70 53 69 7a 65 3b | 09 09 09 2f 2f 20 49 66 |topSize;|...// If|
|00002f80| 20 74 68 65 20 72 65 63 | 6f 72 64 20 70 61 73 73 | the rec|ord pass|
|00002f90| 65 73 20 74 68 65 20 65 | 6e 64 20 6f 66 20 74 68 |es the e|nd of th|
|00002fa0| 65 20 62 75 66 66 65 72 | 2e 2e 2e 0d 09 09 09 2a |e buffer|.......*|
|00002fb0| 73 65 63 6f 6e 64 41 64 | 64 72 20 3d 20 62 75 66 |secondAd|dr = buf|
|00002fc0| 66 53 74 61 72 74 3b 09 | 09 2f 2f 20 2e 2e 2e 20 |fStart;.|.// ... |
|00002fd0| 74 68 65 6e 20 70 61 73 | 73 20 74 68 65 20 61 64 |then pas|s the ad|
|00002fe0| 64 72 65 73 73 20 66 6f | 72 20 74 68 65 20 73 65 |dress fo|r the se|
|00002ff0| 63 6f 6e 64 20 70 61 72 | 74 0d 09 09 09 7d 0d 09 |cond par|t....}..|
|00003000| 09 0d 09 09 2f 2f 20 46 | 69 78 20 75 70 20 74 68 |....// F|ix up th|
|00003010| 65 20 6e 65 78 74 20 77 | 72 69 74 65 20 70 6f 69 |e next w|rite poi|
|00003020| 6e 74 65 72 3a 0d 09 09 | 0d 09 09 6e 65 78 74 57 |nter:...|...nextW|
|00003030| 72 69 74 65 20 2b 3d 20 | 72 65 63 6f 72 64 53 69 |rite += |recordSi|
|00003040| 7a 65 3b 0d 09 09 69 66 | 20 28 6e 65 78 74 57 72 |ze;...if| (nextWr|
|00003050| 69 74 65 20 3e 20 62 75 | 66 66 45 6e 64 29 0d 09 |ite > bu|ffEnd)..|
|00003060| 09 09 6e 65 78 74 57 72 | 69 74 65 20 3d 20 62 75 |..nextWr|ite = bu|
|00003070| 66 66 53 74 61 72 74 20 | 2b 20 73 65 63 6f 6e 64 |ffStart |+ second|
|00003080| 50 61 72 74 3b 0d 09 09 | 0d 09 09 2f 2f 20 44 6f |Part;...|...// Do|
|00003090| 6e 27 74 20 66 6f 72 67 | 65 74 20 74 6f 20 6d 6f |n't forg|et to mo|
|000030a0| 76 65 20 74 68 65 20 72 | 65 67 69 73 74 65 72 20 |ve the r|egister |
|000030b0| 63 6f 70 79 20 62 61 63 | 6b 20 69 6e 74 6f 20 74 |copy bac|k into t|
|000030c0| 68 65 20 67 6c 6f 62 61 | 6c 73 20 62 6c 6f 63 6b |he globa|ls block|
|000030d0| 3a 0d 09 09 0d 09 09 67 | 6c 6f 62 61 6c 73 2d 3e |:......g|lobals->|
|000030e0| 66 4e 65 78 74 57 72 69 | 74 65 50 74 72 20 3d 20 |fNextWri|tePtr = |
|000030f0| 6e 65 78 74 57 72 69 74 | 65 3b 0d 09 09 0d 09 09 |nextWrit|e;......|
|00003100| 7d 0d 09 0d 09 72 65 74 | 75 72 6e 3b 0d 09 0d 09 |}....ret|urn;....|
|00003110| 7d 0d 73 6e 75 6d 20 47 | 65 74 54 72 61 63 65 50 |}.snum G|etTraceP|
|00003120| 72 6f 63 28 54 72 61 63 | 65 47 6c 6f 62 61 6c 73 |roc(Trac|eGlobals|
|00003130| 20 2a 67 6c 6f 62 61 6c | 73 2c 20 54 72 61 63 65 | *global|s, Trace|
|00003140| 50 61 72 61 6d 42 6c 6f | 63 6b 20 2a 70 61 72 61 |ParamBlo|ck *para|
|00003150| 6d 50 74 72 29 0d 7b 0d | 0d 09 70 61 72 61 6d 50 |mPtr).{.|..paramP|
|00003160| 74 72 2d 3e 75 2e 74 72 | 61 63 65 50 72 6f 63 2e |tr->u.tr|aceProc.|
|00003170| 74 72 61 63 65 50 72 6f | 63 50 74 72 20 3d 20 28 |tracePro|cPtr = (|
|00003180| 54 72 61 63 65 50 72 6f | 63 50 74 72 29 54 72 61 |TracePro|cPtr)Tra|
|00003190| 63 65 50 72 6f 63 3b 0d | 09 70 61 72 61 6d 50 74 |ceProc;.|.paramPt|
|000031a0| 72 2d 3e 75 2e 74 72 61 | 63 65 50 72 6f 63 2e 74 |r->u.tra|ceProc.t|
|000031b0| 72 61 63 65 56 61 6c 75 | 65 20 3d 20 28 6c 6f 6e |raceValu|e = (lon|
|000031c0| 67 29 20 67 6c 6f 62 61 | 6c 73 3b 0d 0d 09 72 65 |g) globa|ls;...re|
|000031d0| 74 75 72 6e 28 6e 6f 45 | 72 72 29 3b 0d 7d 0d 0d |turn(noE|rr);.}..|
|000031e0| 73 6e 75 6d 20 47 65 74 | 54 72 61 63 65 53 74 61 |snum Get|TraceSta|
|000031f0| 74 75 73 28 54 72 61 63 | 65 47 6c 6f 62 61 6c 73 |tus(Trac|eGlobals|
|00003200| 20 2a 67 6c 6f 62 61 6c | 73 2c 20 54 72 61 63 65 | *global|s, Trace|
|00003210| 50 61 72 61 6d 42 6c 6f | 63 6b 20 2a 70 61 72 61 |ParamBlo|ck *para|
|00003220| 6d 50 74 72 29 0d 09 7b | 0d 09 54 72 61 63 65 53 |mPtr)..{|..TraceS|
|00003230| 74 61 74 75 73 42 6c 6b | 20 2a 73 74 61 74 75 73 |tatusBlk| *status|
|00003240| 50 74 72 3b 0d 09 50 74 | 72 20 6e 65 78 74 52 65 |Ptr;..Pt|r nextRe|
|00003250| 61 64 3b 0d 09 50 74 72 | 20 6e 65 78 74 57 72 69 |ad;..Ptr| nextWri|
|00003260| 74 65 3b 0d 09 6c 6f 6e | 67 20 62 79 74 65 73 42 |te;..lon|g bytesB|
|00003270| 75 66 66 65 72 65 64 3b | 0d 09 63 68 61 72 20 2a |uffered;|..char *|
|00003280| 73 2c 20 2a 74 3b 0d 09 | 73 68 6f 72 74 20 6c 65 |s, *t;..|short le|
|00003290| 6e 3b 0d 09 73 68 6f 72 | 74 20 69 3b 0d 09 0d 09 |n;..shor|t i;....|
|000032a0| 73 74 61 74 75 73 50 74 | 72 20 3d 20 70 61 72 61 |statusPt|r = para|
|000032b0| 6d 50 74 72 2d 3e 75 2e | 67 65 74 53 74 61 74 75 |mPtr->u.|getStatu|
|000032c0| 73 2e 73 74 61 74 75 73 | 50 74 72 3b 0d 09 0d 09 |s.status|Ptr;....|
|000032d0| 73 74 61 74 75 73 50 74 | 72 2d 3e 6f 6e 6c 69 6e |statusPt|r->onlin|
|000032e0| 65 20 3d 20 67 6c 6f 62 | 61 6c 73 2d 3e 66 54 72 |e = glob|als->fTr|
|000032f0| 61 63 65 4f 6e 6c 69 6e | 65 3b 0d 09 73 74 61 74 |aceOnlin|e;..stat|
|00003300| 75 73 50 74 72 2d 3e 62 | 75 66 66 65 72 45 6e 61 |usPtr->b|ufferEna|
|00003310| 62 6c 65 64 20 3d 20 67 | 6c 6f 62 61 6c 73 2d 3e |bled = g|lobals->|
|00003320| 66 42 75 66 66 65 72 45 | 6e 61 62 6c 65 64 3b 0d |fBufferE|nabled;.|
|00003330| 09 73 74 61 74 75 73 50 | 74 72 2d 3e 66 69 6c 65 |.statusP|tr->file|
|00003340| 45 6e 61 62 6c 65 64 20 | 3d 20 67 6c 6f 62 61 6c |Enabled |= global|
|00003350| 73 2d 3e 66 46 69 6c 65 | 45 6e 61 62 6c 65 64 3b |s->fFile|Enabled;|
|00003360| 0d 09 73 74 61 74 75 73 | 50 74 72 2d 3e 61 75 74 |..status|Ptr->aut|
|00003370| 6f 57 72 69 74 65 20 3d | 20 67 6c 6f 62 61 6c 73 |oWrite =| globals|
|00003380| 2d 3e 66 41 75 74 6f 6d | 61 74 69 63 57 72 69 74 |->fAutom|aticWrit|
|00003390| 65 3b 0d 0d 09 73 74 61 | 74 75 73 50 74 72 2d 3e |e;...sta|tusPtr->|
|000033a0| 62 75 66 66 65 72 53 69 | 7a 65 20 3d 20 67 6c 6f |bufferSi|ze = glo|
|000033b0| 62 61 6c 73 2d 3e 66 54 | 72 61 63 65 42 75 66 66 |bals->fT|raceBuff|
|000033c0| 53 69 7a 65 3b 0d 09 73 | 74 61 74 75 73 50 74 72 |Size;..s|tatusPtr|
|000033d0| 2d 3e 62 75 66 66 65 72 | 53 69 7a 65 49 6e 64 65 |->buffer|SizeInde|
|000033e0| 78 20 3d 20 67 6c 6f 62 | 61 6c 73 2d 3e 66 54 72 |x = glob|als->fTr|
|000033f0| 61 63 65 42 75 66 66 53 | 69 7a 65 49 6e 64 65 78 |aceBuffS|izeIndex|
|00003400| 3b 0d 09 73 74 61 74 75 | 73 50 74 72 2d 3e 62 72 |;..statu|sPtr->br|
|00003410| 65 61 6b 4f 6e 63 65 54 | 68 65 6e 43 6c 65 61 72 |eakOnceT|henClear|
|00003420| 20 3d 20 67 6c 6f 62 61 | 6c 73 2d 3e 66 42 72 65 | = globa|ls->fBre|
|00003430| 61 6b 4f 6e 63 65 54 68 | 65 6e 43 6c 65 61 72 3b |akOnceTh|enClear;|
|00003440| 20 0d 09 73 74 61 74 75 | 73 50 74 72 2d 3e 44 65 | ..statu|sPtr->De|
|00003450| 62 75 67 4d 61 72 6b 55 | 6e 73 65 74 20 3d 20 67 |bugMarkU|nset = g|
|00003460| 6c 6f 62 61 6c 73 2d 3e | 66 44 65 62 75 67 4d 61 |lobals->|fDebugMa|
|00003470| 72 6b 55 6e 73 65 74 3b | 0d 09 73 74 61 74 75 73 |rkUnset;|..status|
|00003480| 50 74 72 2d 3e 54 72 61 | 63 65 4f 6e 53 74 61 72 |Ptr->Tra|ceOnStar|
|00003490| 74 75 70 20 3d 20 67 6c | 6f 62 61 6c 73 2d 3e 66 |tup = gl|obals->f|
|000034a0| 54 72 61 63 65 4f 6e 53 | 74 61 72 74 75 70 3b 0d |TraceOnS|tartup;.|
|000034b0| 09 69 66 20 28 20 21 20 | 67 6c 6f 62 61 6c 73 2d |.if ( ! |globals-|
|000034c0| 3e 66 42 75 66 66 65 72 | 45 6e 61 62 6c 65 64 29 |>fBuffer|Enabled)|
|000034d0| 0d 09 09 62 79 74 65 73 | 42 75 66 66 65 72 65 64 |...bytes|Buffered|
|000034e0| 20 3d 20 30 3b 0d 09 65 | 6c 73 65 0d 09 09 7b 0d | = 0;..e|lse...{.|
|000034f0| 09 09 6e 65 78 74 52 65 | 61 64 20 3d 20 67 6c 6f |..nextRe|ad = glo|
|00003500| 62 61 6c 73 2d 3e 66 4e | 65 78 74 52 65 61 64 50 |bals->fN|extReadP|
|00003510| 74 72 3b 0d 09 09 6e 65 | 78 74 57 72 69 74 65 20 |tr;...ne|xtWrite |
|00003520| 3d 20 67 6c 6f 62 61 6c | 73 2d 3e 66 4e 65 78 74 |= global|s->fNext|
|00003530| 57 72 69 74 65 50 74 72 | 3b 0d 09 09 69 66 20 28 |WritePtr|;...if (|
|00003540| 6e 65 78 74 52 65 61 64 | 20 3c 20 6e 65 78 74 57 |nextRead| < nextW|
|00003550| 72 69 74 65 29 0d 09 09 | 09 62 79 74 65 73 42 75 |rite)...|.bytesBu|
|00003560| 66 66 65 72 65 64 20 3d | 20 6e 65 78 74 57 72 69 |ffered =| nextWri|
|00003570| 74 65 20 2d 20 6e 65 78 | 74 52 65 61 64 3b 0d 09 |te - nex|tRead;..|
|00003580| 09 65 6c 73 65 20 69 66 | 20 28 6e 65 78 74 52 65 |.else if| (nextRe|
|00003590| 61 64 20 3e 20 6e 65 78 | 74 57 72 69 74 65 29 0d |ad > nex|tWrite).|
|000035a0| 09 09 09 62 79 74 65 73 | 42 75 66 66 65 72 65 64 |...bytes|Buffered|
|000035b0| 20 3d 20 67 6c 6f 62 61 | 6c 73 2d 3e 66 54 72 61 | = globa|ls->fTra|
|000035c0| 63 65 42 75 66 66 53 69 | 7a 65 20 2d 20 28 6e 65 |ceBuffSi|ze - (ne|
|000035d0| 78 74 52 65 61 64 20 2d | 20 6e 65 78 74 57 72 69 |xtRead -| nextWri|
|000035e0| 74 65 29 3b 0d 09 09 65 | 6c 73 65 0d 09 09 09 62 |te);...e|lse....b|
|000035f0| 79 74 65 73 42 75 66 66 | 65 72 65 64 20 3d 20 30 |ytesBuff|ered = 0|
|00003600| 3b 0d 09 09 7d 0d 09 73 | 74 61 74 75 73 50 74 72 |;...}..s|tatusPtr|
|00003610| 2d 3e 62 79 74 65 73 42 | 75 66 66 65 72 65 64 20 |->bytesB|uffered |
|00003620| 3d 20 62 79 74 65 73 42 | 75 66 66 65 72 65 64 3b |= bytesB|uffered;|
|00003630| 0d 09 09 0d 09 69 66 20 | 28 20 21 20 67 6c 6f 62 |.....if |( ! glob|
|00003640| 61 6c 73 2d 3e 66 46 69 | 6c 65 45 6e 61 62 6c 65 |als->fFi|leEnable|
|00003650| 64 29 0d 09 09 7b 0d 09 | 09 73 74 61 74 75 73 50 |d)...{..|.statusP|
|00003660| 74 72 2d 3e 62 79 74 65 | 73 57 72 69 74 74 65 6e |tr->byte|sWritten|
|00003670| 20 3d 20 30 3b 0d 09 09 | 73 74 61 74 75 73 50 74 | = 0;...|statusPt|
|00003680| 72 2d 3e 66 69 6c 65 56 | 6f 6c 75 6d 65 20 3d 20 |r->fileV|olume = |
|00003690| 30 3b 0d 09 09 74 20 3d | 20 73 74 61 74 75 73 50 |0;...t =| statusP|
|000036a0| 74 72 2d 3e 66 69 6c 65 | 4e 61 6d 65 3b 0d 09 09 |tr->file|Name;...|
|000036b0| 66 6f 72 20 28 69 20 3d | 20 30 3b 20 69 20 3c 20 |for (i =| 0; i < |
|000036c0| 73 69 7a 65 6f 66 28 73 | 74 61 74 75 73 50 74 72 |sizeof(s|tatusPtr|
|000036d0| 2d 3e 66 69 6c 65 4e 61 | 6d 65 29 3b 20 69 2b 2b |->fileNa|me); i++|
|000036e0| 29 0d 09 09 09 2a 74 2b | 2b 20 3d 20 30 3b 0d 09 |)....*t+|+ = 0;..|
|000036f0| 09 7d 0d 09 65 6c 73 65 | 0d 09 09 7b 0d 09 09 73 |.}..else|...{...s|
|00003700| 74 61 74 75 73 50 74 72 | 2d 3e 62 79 74 65 73 57 |tatusPtr|->bytesW|
|00003710| 72 69 74 74 65 6e 20 3d | 20 67 6c 6f 62 61 6c 73 |ritten =| globals|
|00003720| 2d 3e 66 42 79 74 65 73 | 57 72 69 74 74 65 6e 3b |->fBytes|Written;|
|00003730| 0d 09 09 73 74 61 74 75 | 73 50 74 72 2d 3e 66 69 |...statu|sPtr->fi|
|00003740| 6c 65 56 6f 6c 75 6d 65 | 20 3d 20 67 6c 6f 62 61 |leVolume| = globa|
|00003750| 6c 73 2d 3e 66 56 52 65 | 66 4e 75 6d 3b 0d 09 09 |ls->fVRe|fNum;...|
|00003760| 6c 65 6e 20 3d 20 67 6c | 6f 62 61 6c 73 2d 3e 66 |len = gl|obals->f|
|00003770| 54 72 61 63 65 46 69 6c | 65 4e 61 6d 65 5b 30 5d |TraceFil|eName[0]|
|00003780| 20 2b 20 31 3b 0d 09 09 | 73 20 3d 20 67 6c 6f 62 | + 1;...|s = glob|
|00003790| 61 6c 73 2d 3e 66 54 72 | 61 63 65 46 69 6c 65 4e |als->fTr|aceFileN|
|000037a0| 61 6d 65 3b 0d 09 09 74 | 20 3d 20 73 74 61 74 75 |ame;...t| = statu|
|000037b0| 73 50 74 72 2d 3e 66 69 | 6c 65 4e 61 6d 65 3b 0d |sPtr->fi|leName;.|
|000037c0| 09 09 66 6f 72 20 28 69 | 20 3d 20 30 3b 20 69 20 |..for (i| = 0; i |
|000037d0| 3c 20 6c 65 6e 3b 20 69 | 2b 2b 29 0d 09 09 09 2a |< len; i|++)....*|
|000037e0| 74 2b 2b 20 3d 20 2a 73 | 2b 2b 3b 09 09 0d 09 09 |t++ = *s|++;.....|
|000037f0| 66 6f 72 20 28 69 20 3d | 20 6c 65 6e 3b 20 69 20 |for (i =| len; i |
|00003800| 3c 20 73 69 7a 65 6f 66 | 28 73 74 61 74 75 73 50 |< sizeof|(statusP|
|00003810| 74 72 2d 3e 66 69 6c 65 | 4e 61 6d 65 29 3b 20 69 |tr->file|Name); i|
|00003820| 2b 2b 29 0d 09 09 09 2a | 74 2b 2b 20 3d 20 30 3b |++)....*|t++ = 0;|
|00003830| 0d 09 09 7d 0d 09 09 0d | 09 72 65 74 75 72 6e 28 |...}....|.return(|
|00003840| 6e 6f 45 72 72 29 3b 0d | 09 0d 09 7d 0d 0d 2f 2a |noErr);.|...}../*|
|00003850| 20 0d 09 54 68 69 73 20 | 69 73 20 63 61 6c 6c 65 | ..This |is calle|
|00003860| 64 20 6f 6e 63 65 20 62 | 79 20 44 52 56 52 20 6f |d once b|y DRVR o|
|00003870| 70 65 6e 2e 2e 2e 20 20 | 49 74 20 69 6e 69 74 73 |pen... |It inits|
|00003880| 20 74 68 65 20 67 6c 6f | 62 61 6c 73 2c 20 61 6e | the glo|bals, an|
|00003890| 64 20 66 69 6e 64 73 20 | 6f 75 74 20 74 68 65 20 |d finds |out the |
|000038a0| 0d 09 64 72 69 76 65 72 | 20 6e 61 6d 65 20 74 68 |..driver| name th|
|000038b0| 61 74 20 54 72 61 63 65 | 20 77 69 6c 6c 20 74 72 |at Trace| will tr|
|000038c0| 61 63 65 2e 0d 2a 2f 0d | 0d 76 6f 69 64 20 49 6e |ace..*/.|.void In|
|000038d0| 69 74 54 72 61 63 65 28 | 54 72 61 63 65 47 6c 6f |itTrace(|TraceGlo|
|000038e0| 62 61 6c 73 20 2a 67 6c | 6f 62 61 6c 73 29 0d 7b |bals *gl|obals).{|
|000038f0| 0d 09 67 6c 6f 62 61 6c | 73 2d 3e 66 43 68 65 63 |..global|s->fChec|
|00003900| 6b 49 44 20 3d 20 27 54 | 52 41 43 27 3b 0d 09 67 |kID = 'T|RAC';..g|
|00003910| 6c 6f 62 61 6c 73 2d 3e | 66 4d 79 43 72 65 61 74 |lobals->|fMyCreat|
|00003920| 6f 72 20 3d 20 27 42 4e | 4e 59 27 3b 0d 09 67 6c |or = 'BN|NY';..gl|
|00003930| 6f 62 61 6c 73 2d 3e 66 | 4d 79 46 69 6c 65 54 79 |obals->f|MyFileTy|
|00003940| 70 65 20 3d 20 6b 50 72 | 65 66 73 4f 53 54 79 70 |pe = kPr|efsOSTyp|
|00003950| 65 3b 09 2f 2f 20 70 72 | 65 66 65 72 65 6e 63 65 |e;.// pr|eference|
|00003960| 20 66 69 6c 65 20 74 79 | 70 65 20 0d 0d 09 67 6c | file ty|pe ...gl|
|00003970| 6f 62 61 6c 73 2d 3e 66 | 42 75 66 66 53 74 61 72 |obals->f|BuffStar|
|00003980| 74 50 74 72 20 3d 20 6e | 69 6c 3b 0d 09 67 6c 6f |tPtr = n|il;..glo|
|00003990| 62 61 6c 73 2d 3e 66 42 | 75 66 66 45 6e 64 50 74 |bals->fB|uffEndPt|
|000039a0| 72 20 3d 20 6e 69 6c 3b | 09 09 0d 09 67 6c 6f 62 |r = nil;|....glob|
|000039b0| 61 6c 73 2d 3e 66 4e 65 | 78 74 52 65 61 64 50 74 |als->fNe|xtReadPt|
|000039c0| 72 20 3d 20 6e 69 6c 3b | 0d 09 67 6c 6f 62 61 6c |r = nil;|..global|
|000039d0| 73 2d 3e 66 4e 65 78 74 | 57 72 69 74 65 50 74 72 |s->fNext|WritePtr|
|000039e0| 20 3d 20 6e 69 6c 3b 0d | 0d 09 67 6c 6f 62 61 6c | = nil;.|..global|
|000039f0| 73 2d 3e 66 54 72 61 63 | 65 4c 6f 63 6b 20 3d 20 |s->fTrac|eLock = |
|00003a00| 66 61 6c 73 65 3b 0d 09 | 67 6c 6f 62 61 6c 73 2d |false;..|globals-|
|00003a10| 3e 66 42 75 66 66 65 72 | 45 6e 61 62 6c 65 64 20 |>fBuffer|Enabled |
|00003a20| 3d 20 66 61 6c 73 65 3b | 0d 09 67 6c 6f 62 61 6c |= false;|..global|
|00003a30| 73 2d 3e 66 46 69 6c 65 | 45 6e 61 62 6c 65 64 20 |s->fFile|Enabled |
|00003a40| 3d 20 66 61 6c 73 65 3b | 0d 09 67 6c 6f 62 61 6c |= false;|..global|
|00003a50| 73 2d 3e 66 54 72 61 63 | 65 4f 6e 6c 69 6e 65 20 |s->fTrac|eOnline |
|00003a60| 3d 20 66 61 6c 73 65 3b | 0d 09 67 6c 6f 62 61 6c |= false;|..global|
|00003a70| 73 2d 3e 66 46 69 6c 65 | 49 73 4f 70 65 6e 20 3d |s->fFile|IsOpen =|
|00003a80| 20 66 61 6c 73 65 3b 0d | 09 67 6c 6f 62 61 6c 73 | false;.|.globals|
|00003a90| 2d 3e 66 41 75 74 6f 6d | 61 74 69 63 57 72 69 74 |->fAutom|aticWrit|
|00003aa0| 65 20 3d 20 66 61 6c 73 | 65 3b 0d 09 67 6c 6f 62 |e = fals|e;..glob|
|00003ab0| 61 6c 73 2d 3e 66 4c 6f | 63 6b 65 64 4f 75 74 46 |als->fLo|ckedOutF|
|00003ac0| 6c 61 67 20 3d 20 66 61 | 6c 73 65 3b 0d 09 0d 09 |lag = fa|lse;....|
|00003ad0| 67 6c 6f 62 61 6c 73 2d | 3e 66 42 79 74 65 73 57 |globals-|>fBytesW|
|00003ae0| 72 69 74 74 65 6e 20 3d | 20 30 3b 0d 09 67 6c 6f |ritten =| 0;..glo|
|00003af0| 62 61 6c 73 2d 3e 66 57 | 72 69 74 65 45 72 72 20 |bals->fW|riteErr |
|00003b00| 3d 20 30 3b 0d 0d 09 67 | 6c 6f 62 61 6c 73 2d 3e |= 0;...g|lobals->|
|00003b10| 66 44 72 69 76 65 72 73 | 52 65 66 4e 75 6d 20 3d |fDrivers|RefNum =|
|00003b20| 20 30 3b 0d 09 0d 09 67 | 6c 6f 62 61 6c 73 2d 3e | 0;....g|lobals->|
|00003b30| 66 54 69 6d 65 53 74 61 | 6d 70 54 79 70 65 20 3d |fTimeSta|mpType =|
|00003b40| 20 31 3b 20 2f 2f 20 41 | 6c 77 61 79 73 20 75 73 | 1; // A|lways us|
|00003b50| 65 20 64 61 74 65 2f 74 | 69 6d 65 20 66 6f 72 20 |e date/t|ime for |
|00003b60| 6e 6f 77 0d 09 67 6c 6f | 62 61 6c 73 2d 3e 66 42 |now..glo|bals->fB|
|00003b70| 72 65 61 6b 4f 6e 63 65 | 54 68 65 6e 43 6c 65 61 |reakOnce|ThenClea|
|00003b80| 72 20 3d 20 74 72 75 65 | 3b 0d 0d 09 72 65 74 75 |r = true|;...retu|
|00003b90| 72 6e 3b 09 0d 7d 0d 0d | 73 6e 75 6d 20 4f 70 65 |rn;..}..|snum Ope|
|00003ba0| 6e 54 72 61 63 65 46 69 | 6c 65 28 54 72 61 63 65 |nTraceFi|le(Trace|
|00003bb0| 47 6c 6f 62 61 6c 73 20 | 2a 67 6c 6f 62 61 6c 73 |Globals |*globals|
|00003bc0| 29 0d 09 7b 0d 09 72 65 | 67 69 73 74 65 72 20 73 |)..{..re|gister s|
|00003bd0| 6e 75 6d 20 72 65 73 75 | 6c 74 3b 0d 09 72 65 67 |num resu|lt;..reg|
|00003be0| 69 73 74 65 72 20 63 68 | 61 72 20 2a 66 69 6c 65 |ister ch|ar *file|
|00003bf0| 4e 61 6d 65 3b 0d 09 72 | 65 67 69 73 74 65 72 20 |Name;..r|egister |
|00003c00| 73 68 6f 72 74 20 76 52 | 65 66 4e 75 6d 3b 0d 0d |short vR|efNum;..|
|00003c10| 09 69 66 20 28 67 6c 6f | 62 61 6c 73 2d 3e 66 46 |.if (glo|bals->fF|
|00003c20| 69 6c 65 49 73 4f 70 65 | 6e 29 0d 09 09 72 65 73 |ileIsOpe|n)...res|
|00003c30| 75 6c 74 20 3d 20 74 6d | 66 6f 45 72 72 3b 20 2f |ult = tm|foErr; /|
|00003c40| 2f 20 22 74 6f 6f 20 6d | 61 6e 79 20 66 69 6c 65 |/ "too m|any file|
|00003c50| 73 20 6f 70 65 6e 22 20 | 69 66 20 61 20 66 69 6c |s open" |if a fil|
|00003c60| 65 20 69 73 20 61 6c 72 | 65 61 64 79 20 6f 70 65 |e is alr|eady ope|
|00003c70| 6e 0d 09 65 6c 73 65 0d | 09 09 7b 0d 09 2f 2f 09 |n..else.|..{..//.|
|00003c80| 28 76 6f 69 64 29 20 52 | 73 74 46 4c 6f 63 6b 28 |(void) R|stFLock(|
|00003c90| 67 6c 6f 62 61 6c 73 2d | 3e 66 54 72 61 63 65 46 |globals-|>fTraceF|
|00003ca0| 69 6c 65 4e 61 6d 65 2c | 67 6c 6f 62 61 6c 73 2d |ileName,|globals-|
|00003cb0| 3e 66 56 52 65 66 4e 75 | 6d 29 3b 0d 0d 09 09 66 |>fVRefNu|m);....f|
|00003cc0| 69 6c 65 4e 61 6d 65 20 | 3d 20 67 6c 6f 62 61 6c |ileName |= global|
|00003cd0| 73 2d 3e 66 54 72 61 63 | 65 46 69 6c 65 4e 61 6d |s->fTrac|eFileNam|
|00003ce0| 65 3b 0d 09 09 76 52 65 | 66 4e 75 6d 20 3d 20 67 |e;...vRe|fNum = g|
|00003cf0| 6c 6f 62 61 6c 73 2d 3e | 66 56 52 65 66 4e 75 6d |lobals->|fVRefNum|
|00003d00| 3b 0d 09 09 0d 09 09 2f | 2f 20 4f 70 65 6e 20 74 |;....../|/ Open t|
|00003d10| 68 65 20 66 69 6c 65 20 | 2d 20 72 65 74 75 72 6e |he file |- return|
|00003d20| 20 61 6e 20 65 72 72 6f | 72 20 69 66 20 66 69 6c | an erro|r if fil|
|00003d30| 65 20 69 73 20 6e 6f 74 | 20 66 6f 75 6e 64 0d 09 |e is not| found..|
|00003d40| 09 2f 2f 20 28 45 6e 61 | 62 6c 65 54 72 61 63 65 |.// (Ena|bleTrace|
|00003d50| 46 69 6c 65 20 73 68 6f | 75 6c 64 20 68 61 76 65 |File sho|uld have|
|00003d60| 20 61 6c 72 65 61 64 79 | 20 63 72 65 61 74 65 64 | already| created|
|00003d70| 20 69 74 29 0d 09 09 0d | 09 09 72 65 73 75 6c 74 | it)....|..result|
|00003d80| 20 3d 20 46 53 4f 70 65 | 6e 28 66 69 6c 65 4e 61 | = FSOpe|n(fileNa|
|00003d90| 6d 65 2c 20 76 52 65 66 | 4e 75 6d 2c 20 26 28 67 |me, vRef|Num, &(g|
|00003da0| 6c 6f 62 61 6c 73 2d 3e | 66 46 69 6c 65 52 65 66 |lobals->|fFileRef|
|00003db0| 4e 75 6d 29 29 3b 0d 09 | 09 09 0d 09 09 2f 2f 20 |Num));..|.....// |
|00003dc0| 53 65 74 20 74 68 65 20 | 66 69 6c 65 20 70 6f 73 |Set the |file pos|
|00003dd0| 69 74 69 6f 6e 20 74 6f | 20 74 68 65 20 65 6e 64 |ition to| the end|
|00003de0| 20 6f 66 20 74 68 65 20 | 66 69 6c 65 2e 0d 09 09 | of the |file....|
|00003df0| 0d 09 09 69 66 20 28 72 | 65 73 75 6c 74 20 3d 3d |...if (r|esult ==|
|00003e00| 20 6e 6f 45 72 72 29 0d | 09 09 09 7b 0d 09 09 09 | noErr).|...{....|
|00003e10| 09 28 76 6f 69 64 29 20 | 53 65 74 46 50 6f 73 28 |.(void) |SetFPos(|
|00003e20| 67 6c 6f 62 61 6c 73 2d | 3e 66 46 69 6c 65 52 65 |globals-|>fFileRe|
|00003e30| 66 4e 75 6d 2c 20 66 73 | 46 72 6f 6d 4c 45 4f 46 |fNum, fs|FromLEOF|
|00003e40| 2c 20 30 29 3b 0d 09 09 | 09 09 67 6c 6f 62 61 6c |, 0);...|..global|
|00003e50| 73 2d 3e 66 46 69 6c 65 | 49 73 4f 70 65 6e 20 3d |s->fFile|IsOpen =|
|00003e60| 20 31 3b 0d 09 09 09 7d | 0d 09 09 7d 0d 09 09 0d | 1;....}|...}....|
|00003e70| 09 72 65 74 75 72 6e 28 | 72 65 73 75 6c 74 29 3b |.return(|result);|
|00003e80| 0d 09 0d 09 7d 0d 0d 2f | 2a 20 0d 2a 2a 09 45 66 |....}../|* .**.Ef|
|00003e90| 66 65 63 74 69 76 6c 79 | 20 65 72 61 73 65 73 20 |fectivly| erases |
|00003ea0| 74 68 65 20 64 61 74 61 | 20 69 6e 20 61 6e 20 6f |the data| in an o|
|00003eb0| 75 74 70 75 74 20 66 69 | 6c 65 2c 0d 2a 2a 09 77 |utput fi|le,.**.w|
|00003ec0| 69 74 68 6f 75 74 20 61 | 6c 6c 20 74 68 65 20 68 |ithout a|ll the h|
|00003ed0| 61 73 73 6c 65 73 20 6f | 66 20 75 73 69 6e 67 20 |assles o|f using |
|00003ee0| 66 69 6e 64 65 72 20 0d | 2a 2f 0d 73 6e 75 6d 20 |finder .|*/.snum |
|00003ef0| 52 65 73 65 74 45 4f 46 | 28 54 72 61 63 65 47 6c |ResetEOF|(TraceGl|
|00003f00| 6f 62 61 6c 73 20 2a 67 | 6c 6f 62 61 6c 73 29 0d |obals *g|lobals).|
|00003f10| 7b 0d 72 65 67 69 73 74 | 65 72 20 73 6e 75 6d 20 |{.regist|er snum |
|00003f20| 72 65 73 75 6c 74 3b 0d | 09 2f 2f 20 49 66 20 74 |result;.|.// If t|
|00003f30| 68 65 20 20 74 72 61 63 | 65 20 66 69 6c 65 20 69 |he trac|e file i|
|00003f40| 73 20 65 6e 61 62 6c 65 | 64 2c 20 74 68 65 6e 20 |s enable|d, then |
|00003f50| 6f 70 65 6e 20 74 68 65 | 20 66 69 6c 65 2c 0d 09 |open the| file,..|
|00003f60| 2f 2f 20 61 6e 64 20 73 | 65 74 20 74 68 65 20 65 |// and s|et the e|
|00003f70| 6f 66 2e 2e 2e 0d 09 0d | 09 69 66 20 28 20 21 20 |of......|.if ( ! |
|00003f80| 67 6c 6f 62 61 6c 73 2d | 3e 66 46 69 6c 65 45 6e |globals-|>fFileEn|
|00003f90| 61 62 6c 65 64 20 26 26 | 20 30 29 09 09 2f 2f 20 |abled &&| 0)..// |
|00003fa0| 49 67 6e 6f 72 65 20 74 | 68 69 73 20 69 66 20 66 |Ignore t|his if f|
|00003fb0| 6f 72 20 6e 6f 77 2e 2e | 20 0d 09 09 72 65 73 75 |or now..| ...resu|
|00003fc0| 6c 74 20 3d 20 76 6f 6c | 4f 66 66 4c 69 6e 45 72 |lt = vol|OffLinEr|
|00003fd0| 72 3b 20 09 09 2f 2f 20 | 22 56 6f 6c 75 6d 65 20 |r; ..// |"Volume |
|00003fe0| 6e 6f 74 20 6f 6e 2d 6c | 69 6e 65 22 0d 09 65 6c |not on-l|ine"..el|
|00003ff0| 73 65 0d 09 09 7b 09 09 | 0d 09 09 09 72 65 73 75 |se...{..|....resu|
|00004000| 6c 74 20 3d 20 4f 70 65 | 6e 54 72 61 63 65 46 69 |lt = Ope|nTraceFi|
|00004010| 6c 65 28 67 6c 6f 62 61 | 6c 73 29 3b 0d 09 09 09 |le(globa|ls);....|
|00004020| 69 66 20 28 72 65 73 75 | 6c 74 20 3d 3d 20 6e 6f |if (resu|lt == no|
|00004030| 45 72 72 29 0d 09 09 09 | 09 7b 0d 09 09 09 09 09 |Err)....|.{......|
|00004040| 2f 2f 20 53 65 74 20 74 | 68 65 20 45 4f 46 20 74 |// Set t|he EOF t|
|00004050| 6f 20 74 68 65 20 73 74 | 61 72 74 20 6f 66 20 74 |o the st|art of t|
|00004060| 68 65 20 66 69 6c 65 2e | 0d 09 09 09 09 09 28 76 |he file.|......(v|
|00004070| 6f 69 64 29 20 53 65 74 | 45 4f 46 28 67 6c 6f 62 |oid) Set|EOF(glob|
|00004080| 61 6c 73 2d 3e 66 46 69 | 6c 65 52 65 66 4e 75 6d |als->fFi|leRefNum|
|00004090| 2c 30 4c 29 3b 09 09 2f | 2f 20 69 67 6e 6f 72 65 |,0L);../|/ ignore|
|000040a0| 20 65 72 72 6f 72 73 20 | 68 65 72 65 0d 09 09 09 | errors |here....|
|000040b0| 09 09 28 76 6f 69 64 29 | 20 43 6c 6f 73 65 54 72 |..(void)| CloseTr|
|000040c0| 61 63 65 46 69 6c 65 28 | 67 6c 6f 62 61 6c 73 29 |aceFile(|globals)|
|000040d0| 3b 09 2f 2f 20 69 67 6e | 6f 72 65 20 65 72 72 6f |;.// ign|ore erro|
|000040e0| 72 73 20 68 65 72 65 0d | 09 09 09 09 09 28 76 6f |rs here.|.....(vo|
|000040f0| 69 64 29 20 46 6c 75 73 | 68 56 6f 6c 28 6e 69 6c |id) Flus|hVol(nil|
|00004100| 2c 20 67 6c 6f 62 61 6c | 73 2d 3e 66 56 52 65 66 |, global|s->fVRef|
|00004110| 4e 75 6d 29 3b 20 09 09 | 2f 2f 20 69 67 6e 6f 72 |Num); ..|// ignor|
|00004120| 65 20 65 72 72 6f 72 73 | 20 68 65 72 65 0d 09 09 |e errors| here...|
|00004130| 09 09 09 67 6c 6f 62 61 | 6c 73 2d 3e 66 42 79 74 |...globa|ls->fByt|
|00004140| 65 73 57 72 69 74 74 65 | 6e 20 3d 20 30 4c 3b 0d |esWritte|n = 0L;.|
|00004150| 09 09 09 09 7d 0d 09 09 | 7d 0d 09 72 65 74 75 72 |....}...|}..retur|
|00004160| 6e 28 72 65 73 75 6c 74 | 29 3b 0d 7d 0d 0d 0d 2f |n(result|);.}.../|
|00004170| 2a 2a 0d 2a 2a 2a 09 09 | 44 72 69 76 65 72 20 74 |**.***..|Driver t|
|00004180| 6f 20 43 44 45 56 20 0d | 2a 2a 2f 0d 0d 73 6e 75 |o CDEV .|**/..snu|
|00004190| 6d 20 53 65 6e 64 4d 61 | 73 6b 54 6f 43 64 65 76 |m SendMa|skToCdev|
|000041a0| 28 54 72 61 63 65 47 6c | 6f 62 61 6c 73 20 2a 67 |(TraceGl|obals *g|
|000041b0| 6c 6f 62 61 6c 73 2c 20 | 54 72 61 63 65 50 61 72 |lobals, |TracePar|
|000041c0| 61 6d 42 6c 6f 63 6b 20 | 2a 70 61 72 61 6d 50 74 |amBlock |*paramPt|
|000041d0| 72 2c 73 68 6f 72 74 20 | 63 73 43 6f 64 65 29 0d |r,short |csCode).|
|000041e0| 7b 0d 0d 09 69 66 20 28 | 63 73 43 6f 64 65 20 3d |{...if (|csCode =|
|000041f0| 3d 20 6b 53 65 6e 64 43 | 64 65 76 42 72 65 61 6b |= kSendC|devBreak|
|00004200| 4d 61 73 6b 29 09 09 0d | 09 09 44 6f 43 6f 70 79 |Mask)...|..DoCopy|
|00004210| 4d 61 73 6b 28 67 6c 6f | 62 61 6c 73 2d 3e 66 42 |Mask(glo|bals->fB|
|00004220| 72 65 61 6b 4d 61 73 6b | 2c 70 61 72 61 6d 50 74 |reakMask|,paramPt|
|00004230| 72 2d 3e 75 2e 6d 61 73 | 6b 2e 4d 61 73 6b 29 3b |r->u.mas|k.Mask);|
|00004240| 0d 09 65 6c 73 65 0d 09 | 09 69 66 20 28 63 73 43 |..else..|.if (csC|
|00004250| 6f 64 65 20 3d 3d 20 6b | 53 65 6e 64 43 64 65 76 |ode == k|SendCdev|
|00004260| 54 72 61 63 65 4d 61 73 | 6b 29 09 09 0d 09 09 09 |TraceMas|k)......|
|00004270| 44 6f 43 6f 70 79 4d 61 | 73 6b 28 67 6c 6f 62 61 |DoCopyMa|sk(globa|
|00004280| 6c 73 2d 3e 66 54 72 61 | 63 65 4d 61 73 6b 2c 70 |ls->fTra|ceMask,p|
|00004290| 61 72 61 6d 50 74 72 2d | 3e 75 2e 6d 61 73 6b 2e |aramPtr-|>u.mask.|
|000042a0| 4d 61 73 6b 29 3b 0d 0d | 09 67 6c 6f 62 61 6c 73 |Mask);..|.globals|
|000042b0| 2d 3e 66 44 65 62 75 67 | 4d 61 72 6b 55 6e 73 65 |->fDebug|MarkUnse|
|000042c0| 74 20 3d 20 66 61 6c 73 | 65 3b 0d 09 70 61 72 61 |t = fals|e;..para|
|000042d0| 6d 50 74 72 2d 3e 75 2e | 6d 61 73 6b 2e 42 72 65 |mPtr->u.|mask.Bre|
|000042e0| 61 6b 4f 6e 63 65 20 3d | 20 67 6c 6f 62 61 6c 73 |akOnce =| globals|
|000042f0| 2d 3e 66 42 72 65 61 6b | 4f 6e 63 65 54 68 65 6e |->fBreak|OnceThen|
|00004300| 43 6c 65 61 72 3b 09 2f | 2f 20 42 72 65 61 6b 70 |Clear;./|/ Breakp|
|00004310| 6f 69 6e 74 20 6d 65 74 | 68 6f 64 0d 09 72 65 74 |oint met|hod..ret|
|00004320| 75 72 6e 28 6e 6f 45 72 | 72 29 3b 0d 7d 0d 0d 73 |urn(noEr|r);.}..s|
|00004330| 6e 75 6d 20 53 65 74 54 | 72 61 63 65 4f 66 66 6c |num SetT|raceOffl|
|00004340| 69 6e 65 28 54 72 61 63 | 65 47 6c 6f 62 61 6c 73 |ine(Trac|eGlobals|
|00004350| 20 2a 67 6c 6f 62 61 6c | 73 29 0d 09 7b 0d 09 73 | *global|s)..{..s|
|00004360| 6e 75 6d 20 72 65 73 75 | 6c 74 3b 0d 09 43 6e 74 |num resu|lt;..Cnt|
|00004370| 72 6c 50 61 72 61 6d 20 | 63 74 6c 50 42 3b 0d 09 |rlParam |ctlPB;..|
|00004380| 0d 09 69 66 20 28 20 21 | 20 67 6c 6f 62 61 6c 73 |..if ( !| globals|
|00004390| 2d 3e 66 54 72 61 63 65 | 4f 6e 6c 69 6e 65 29 0d |->fTrace|Online).|
|000043a0| 09 09 72 65 73 75 6c 74 | 20 3d 20 76 6f 6c 4f 66 |..result| = volOf|
|000043b0| 66 4c 69 6e 45 72 72 3b | 20 2f 2f 20 22 76 6f 6c |fLinErr;| // "vol|
|000043c0| 75 6d 65 20 6e 6f 74 20 | 6f 6e 2d 6c 69 6e 65 22 |ume not |on-line"|
|000043d0| 0d 09 65 6c 73 65 0d 09 | 09 7b 0d 09 09 0d 09 09 |..else..|.{......|
|000043e0| 2f 2f 20 49 73 73 75 65 | 20 50 42 43 6f 6e 74 72 |// Issue| PBContr|
|000043f0| 6f 6c 20 74 6f 20 74 68 | 65 20 74 61 72 67 65 74 |ol to th|e target|
|00004400| 20 64 72 69 76 65 72 3a | 0d 09 09 0d 09 09 63 74 | driver:|......ct|
|00004410| 6c 50 42 2e 69 6f 43 6f | 6d 70 6c 65 74 69 6f 6e |lPB.ioCo|mpletion|
|00004420| 20 3d 20 30 3b 0d 09 09 | 63 74 6c 50 42 2e 69 6f | = 0;...|ctlPB.io|
|00004430| 43 52 65 66 4e 75 6d 20 | 3d 20 67 6c 6f 62 61 6c |CRefNum |= global|
|00004440| 73 2d 3e 66 44 72 69 76 | 65 72 73 52 65 66 4e 75 |s->fDriv|ersRefNu|
|00004450| 6d 3b 0d 09 09 63 74 6c | 50 42 2e 63 73 43 6f 64 |m;...ctl|PB.csCod|
|00004460| 65 20 3d 20 6b 52 65 6d | 6f 76 65 54 72 61 63 65 |e = kRem|oveTrace|
|00004470| 3b 0d 09 0d 09 09 72 65 | 73 75 6c 74 20 3d 20 50 |;.....re|sult = P|
|00004480| 42 43 6f 6e 74 72 6f 6c | 28 28 50 61 72 61 6d 42 |BControl|((ParamB|
|00004490| 6c 6f 63 6b 52 65 63 20 | 2a 29 20 26 63 74 6c 50 |lockRec |*) &ctlP|
|000044a0| 42 2c 20 66 61 6c 73 65 | 29 3b 09 2f 2f 20 6e 6f |B, false|);.// no|
|000044b0| 74 20 61 73 79 6e 63 0d | 09 0d 09 09 69 66 20 28 |t async.|....if (|
|000044c0| 72 65 73 75 6c 74 20 3d | 3d 20 6e 6f 45 72 72 29 |result =|= noErr)|
|000044d0| 0d 09 09 09 67 6c 6f 62 | 61 6c 73 2d 3e 66 54 72 |....glob|als->fTr|
|000044e0| 61 63 65 4f 6e 6c 69 6e | 65 20 3d 20 66 61 6c 73 |aceOnlin|e = fals|
|000044f0| 65 3b 0d 09 09 7d 0d 09 | 0d 09 72 65 74 75 72 6e |e;...}..|..return|
|00004500| 28 72 65 73 75 6c 74 29 | 3b 0d 09 0d 09 7d 0d 0d |(result)|;....}..|
|00004510| 0d 73 6e 75 6d 20 53 65 | 74 54 72 61 63 65 4f 6e |.snum Se|tTraceOn|
|00004520| 6c 69 6e 65 28 54 72 61 | 63 65 47 6c 6f 62 61 6c |line(Tra|ceGlobal|
|00004530| 73 20 2a 67 6c 6f 62 61 | 6c 73 2c 20 63 68 61 72 |s *globa|ls, char|
|00004540| 20 2a 64 72 69 76 65 72 | 44 6f 74 4e 61 6d 65 29 | *driver|DotName)|
|00004550| 0d 7b 0d 73 6e 75 6d 20 | 72 65 73 75 6c 74 3b 0d |.{.snum |result;.|
|00004560| 43 6e 74 72 6c 50 61 72 | 61 6d 20 63 74 6c 50 42 |CntrlPar|am ctlPB|
|00004570| 3b 0d 73 68 6f 72 74 20 | 78 3b 0d 63 68 61 72 20 |;.short |x;.char |
|00004580| 6c 65 6e 67 74 68 42 79 | 74 65 3b 0d 0d 09 69 66 |lengthBy|te;...if|
|00004590| 20 28 67 6c 6f 62 61 6c | 73 2d 3e 66 54 72 61 63 | (global|s->fTrac|
|000045a0| 65 4f 6e 6c 69 6e 65 29 | 0d 09 09 72 65 73 75 6c |eOnline)|...resul|
|000045b0| 74 20 3d 20 76 6f 6c 4f | 6e 4c 69 6e 45 72 72 3b |t = volO|nLinErr;|
|000045c0| 20 2f 2f 20 22 76 6f 6c | 75 6d 65 20 61 6c 72 65 | // "vol|ume alre|
|000045d0| 61 64 79 20 6f 6e 6c 69 | 6e 65 22 0d 09 65 6c 73 |ady onli|ne"..els|
|000045e0| 65 0d 09 09 7b 0d 09 09 | 0d 09 09 2f 2f 20 46 69 |e...{...|...// Fi|
|000045f0| 6e 64 20 74 68 65 20 72 | 65 66 6e 75 6d 20 6f 66 |nd the r|efnum of|
|00004600| 20 74 68 65 20 63 6f 72 | 72 65 63 74 20 64 72 69 | the cor|rect dri|
|00004610| 76 65 72 3a 0d 09 09 0d | 09 09 69 66 20 28 67 6c |ver:....|..if (gl|
|00004620| 6f 62 61 6c 73 2d 3e 66 | 54 72 61 63 65 42 75 66 |obals->f|TraceBuf|
|00004630| 66 53 69 7a 65 20 3d 3d | 20 30 29 20 0d 09 09 09 |fSize ==| 0) ....|
|00004640| 72 65 73 75 6c 74 20 3d | 20 61 73 70 42 75 66 54 |result =| aspBufT|
|00004650| 6f 6f 53 6d 61 6c 6c 3b | 09 2f 2f 20 42 75 66 66 |ooSmall;|.// Buff|
|00004660| 65 72 20 74 6f 6f 20 73 | 6d 61 6c 6c 2e 20 20 4d |er too s|mall. M|
|00004670| 61 79 20 62 65 20 75 6e | 69 6e 69 74 69 61 6c 69 |ay be un|initiali|
|00004680| 7a 65 64 0d 09 09 65 6c | 73 65 0d 09 09 09 72 65 |zed...el|se....re|
|00004690| 73 75 6c 74 20 3d 20 4f | 70 65 6e 44 72 69 76 65 |sult = O|penDrive|
|000046a0| 72 28 64 72 69 76 65 72 | 44 6f 74 4e 61 6d 65 2c |r(driver|DotName,|
|000046b0| 20 26 28 67 6c 6f 62 61 | 6c 73 2d 3e 66 44 72 69 | &(globa|ls->fDri|
|000046c0| 76 65 72 73 52 65 66 4e | 75 6d 29 29 3b 0d 09 09 |versRefN|um));...|
|000046d0| 0d 09 09 69 66 20 28 72 | 65 73 75 6c 74 20 3d 3d |...if (r|esult ==|
|000046e0| 20 6e 6f 45 72 72 29 0d | 09 09 09 7b 0d 09 09 09 | noErr).|...{....|
|000046f0| 6c 65 6e 67 74 68 42 79 | 74 65 20 3d 20 2a 64 72 |lengthBy|te = *dr|
|00004700| 69 76 65 72 44 6f 74 4e | 61 6d 65 3b 0d 09 09 09 |iverDotN|ame;....|
|00004710| 66 6f 72 20 28 78 3d 30 | 3b 78 3c 6c 65 6e 67 74 |for (x=0|;x<lengt|
|00004720| 68 42 79 74 65 20 2b 20 | 31 3b 78 2b 2b 29 0d 09 |hByte + |1;x++)..|
|00004730| 09 09 09 67 6c 6f 62 61 | 6c 73 2d 3e 66 44 72 69 |...globa|ls->fDri|
|00004740| 76 65 72 50 53 74 72 4e | 61 6d 65 5b 78 5d 20 3d |verPStrN|ame[x] =|
|00004750| 20 2a 64 72 69 76 65 72 | 44 6f 74 4e 61 6d 65 2b | *driver|DotName+|
|00004760| 2b 3b 0d 09 09 09 0d 09 | 09 09 2f 2f 20 49 73 73 |+;......|..// Iss|
|00004770| 75 65 20 50 42 43 6f 6e | 74 72 6f 6c 20 74 6f 20 |ue PBCon|trol to |
|00004780| 74 68 65 20 74 61 72 67 | 65 74 20 64 72 69 76 65 |the targ|et drive|
|00004790| 72 3a 0d 09 09 09 0d 09 | 09 09 63 74 6c 50 42 2e |r:......|..ctlPB.|
|000047a0| 69 6f 43 6f 6d 70 6c 65 | 74 69 6f 6e 20 3d 20 30 |ioComple|tion = 0|
|000047b0| 3b 0d 09 09 09 63 74 6c | 50 42 2e 69 6f 43 52 65 |;....ctl|PB.ioCRe|
|000047c0| 66 4e 75 6d 20 3d 20 67 | 6c 6f 62 61 6c 73 2d 3e |fNum = g|lobals->|
|000047d0| 66 44 72 69 76 65 72 73 | 52 65 66 4e 75 6d 3b 0d |fDrivers|RefNum;.|
|000047e0| 09 09 09 63 74 6c 50 42 | 2e 63 73 43 6f 64 65 20 |...ctlPB|.csCode |
|000047f0| 3d 20 6b 49 6e 73 74 61 | 6c 6c 54 72 61 63 65 3b |= kInsta|llTrace;|
|00004800| 0d 09 09 09 2a 28 28 50 | 72 6f 63 50 74 72 20 2a |....*((P|rocPtr *|
|00004810| 29 20 26 28 63 74 6c 50 | 42 2e 63 73 50 61 72 61 |) &(ctlP|B.csPara|
|00004820| 6d 5b 30 5d 29 29 20 3d | 20 28 50 72 6f 63 50 74 |m[0])) =| (ProcPt|
|00004830| 72 29 20 53 74 72 69 70 | 41 64 64 72 65 73 73 28 |r) Strip|Address(|
|00004840| 28 50 74 72 29 20 54 72 | 61 63 65 50 72 6f 63 29 |(Ptr) Tr|aceProc)|
|00004850| 3b 0d 09 09 09 2a 28 28 | 50 74 72 20 2a 29 20 26 |;....*((|Ptr *) &|
|00004860| 28 63 74 6c 50 42 2e 63 | 73 50 61 72 61 6d 5b 32 |(ctlPB.c|sParam[2|
|00004870| 5d 29 29 20 3d 20 28 50 | 74 72 29 20 67 6c 6f 62 |])) = (P|tr) glob|
|00004880| 61 6c 73 3b 0d 09 09 09 | 0d 09 09 09 72 65 73 75 |als;....|....resu|
|00004890| 6c 74 20 3d 20 50 42 43 | 6f 6e 74 72 6f 6c 28 28 |lt = PBC|ontrol((|
|000048a0| 50 61 72 61 6d 42 6c 6f | 63 6b 52 65 63 20 2a 29 |ParamBlo|ckRec *)|
|000048b0| 20 26 63 74 6c 50 42 2c | 20 66 61 6c 73 65 29 3b | &ctlPB,| false);|
|000048c0| 09 2f 2f 20 6e 6f 74 20 | 61 73 79 6e 63 0d 09 09 |.// not |async...|
|000048d0| 09 0d 09 09 09 69 66 20 | 28 72 65 73 75 6c 74 20 |.....if |(result |
|000048e0| 3d 3d 20 6e 6f 45 72 72 | 29 0d 09 09 09 7b 0d 09 |== noErr|)....{..|
|000048f0| 09 09 09 67 6c 6f 62 61 | 6c 73 2d 3e 66 54 72 61 |...globa|ls->fTra|
|00004900| 63 65 4f 6e 6c 69 6e 65 | 20 3d 20 74 72 75 65 3b |ceOnline| = true;|
|00004910| 0d 09 09 09 7d 0d 09 0d | 09 09 09 7d 20 65 6c 73 |....}...|...} els|
|00004920| 65 20 0d 09 09 09 7b 09 | 0d 09 09 09 09 67 6c 6f |e ....{.|.....glo|
|00004930| 62 61 6c 73 2d 3e 66 44 | 72 69 76 65 72 50 53 74 |bals->fD|riverPSt|
|00004940| 72 4e 61 6d 65 5b 30 5d | 20 3d 20 30 3b 0d 09 09 |rName[0]| = 0;...|
|00004950| 09 7d 0d 09 09 7d 0d 09 | 72 65 74 75 72 6e 28 72 |.}...}..|return(r|
|00004960| 65 73 75 6c 74 29 3b 0d | 7d 0d 0d 4f 53 45 72 72 |esult);.|}..OSErr|
|00004970| 20 54 43 6c 6f 73 65 28 | 43 6e 74 72 6c 50 61 72 | TClose(|CntrlPar|
|00004980| 61 6d 20 2a 63 74 6c 50 | 42 2c 20 44 43 74 6c 50 |am *ctlP|B, DCtlP|
|00004990| 74 72 20 64 43 74 6c 29 | 0d 7b 0d 23 70 72 61 67 |tr dCtl)|.{.#prag|
|000049a0| 6d 61 20 75 6e 75 73 65 | 64 20 28 63 74 6c 50 42 |ma unuse|d (ctlPB|
|000049b0| 2c 64 43 74 6c 29 0d 09 | 72 65 74 75 72 6e 28 63 |,dCtl)..|return(c|
|000049c0| 6c 6f 73 45 72 72 29 3b | 20 2f 2f 20 4e 6f 74 20 |losErr);| // Not |
|000049d0| 61 6c 6c 6f 77 65 64 20 | 74 6f 20 63 6c 6f 73 65 |allowed |to close|
|000049e0| 20 74 68 69 73 20 64 72 | 69 76 65 72 0d 7d 0d 0d | this dr|iver.}..|
|000049f0| 0d 4f 53 45 72 72 20 54 | 43 6f 6e 74 72 6f 6c 28 |.OSErr T|Control(|
|00004a00| 43 6e 74 72 6c 50 61 72 | 61 6d 20 2a 63 74 6c 50 |CntrlPar|am *ctlP|
|00004a10| 42 2c 20 44 43 74 6c 50 | 74 72 20 64 43 74 6c 29 |B, DCtlP|tr dCtl)|
|00004a20| 0d 09 7b 0d 09 72 65 67 | 69 73 74 65 72 20 4f 53 |..{..reg|ister OS|
|00004a30| 45 72 72 20 65 72 72 6f | 72 3b 0d 09 72 65 67 69 |Err erro|r;..regi|
|00004a40| 73 74 65 72 20 73 68 6f | 72 74 20 63 73 43 6f 64 |ster sho|rt csCod|
|00004a50| 65 3b 0d 09 72 65 67 69 | 73 74 65 72 20 54 72 61 |e;..regi|ster Tra|
|00004a60| 63 65 50 61 72 61 6d 42 | 6c 6f 63 6b 20 2a 70 61 |ceParamB|lock *pa|
|00004a70| 72 61 6d 50 74 72 3b 09 | 0d 09 72 65 67 69 73 74 |ramPtr;.|..regist|
|00004a80| 65 72 20 54 72 61 63 65 | 47 6c 6f 62 61 6c 73 20 |er Trace|Globals |
|00004a90| 2a 67 6c 6f 62 61 6c 73 | 3b 0d 09 09 0d 09 2f 2f |*globals|;.....//|
|00004aa0| 20 54 68 65 20 64 43 74 | 6c 53 74 6f 72 61 67 65 | The dCt|lStorage|
|00004ab0| 20 66 69 65 6c 64 20 69 | 6e 20 74 68 65 20 44 43 | field i|n the DC|
|00004ac0| 45 20 65 6e 74 72 79 20 | 63 6f 6e 74 61 69 6e 73 |E entry |contains|
|00004ad0| 20 6f 75 72 20 67 6c 6f | 62 61 6c 73 20 70 6f 69 | our glo|bals poi|
|00004ae0| 6e 74 65 72 0d 0d 09 67 | 6c 6f 62 61 6c 73 20 3d |nter...g|lobals =|
|00004af0| 20 28 54 72 61 63 65 47 | 6c 6f 62 61 6c 73 20 2a | (TraceG|lobals *|
|00004b00| 29 20 64 43 74 6c 2d 3e | 64 43 74 6c 53 74 6f 72 |) dCtl->|dCtlStor|
|00004b10| 61 67 65 3b 0d 09 63 73 | 43 6f 64 65 20 3d 20 63 |age;..cs|Code = c|
|00004b20| 74 6c 50 42 2d 3e 63 73 | 43 6f 64 65 3b 0d 09 0d |tlPB->cs|Code;...|
|00004b30| 09 2f 2f 20 63 68 61 6e | 67 65 20 61 63 63 52 75 |.// chan|ge accRu|
|00004b40| 6e 20 74 6f 20 44 6f 50 | 65 72 69 6f 64 69 63 54 |n to DoP|eriodicT|
|00004b50| 69 6d 65 0d 09 0d 09 69 | 66 20 28 63 73 43 6f 64 |ime....i|f (csCod|
|00004b60| 65 20 3d 3d 20 61 63 63 | 52 75 6e 29 0d 09 09 63 |e == acc|Run)...c|
|00004b70| 73 43 6f 64 65 20 3d 20 | 6b 44 6f 50 65 72 69 6f |sCode = |kDoPerio|
|00004b80| 64 69 63 54 69 6d 65 3b | 0d 0d 09 2f 2f 20 54 68 |dicTime;|...// Th|
|00004b90| 65 20 54 72 61 63 65 50 | 61 72 61 6d 42 6c 6f 63 |e TraceP|aramBloc|
|00004ba0| 6b 20 69 73 20 69 6e 20 | 63 73 50 61 72 61 6d 3a |k is in |csParam:|
|00004bb0| 0d 0d 09 70 61 72 61 6d | 50 74 72 20 3d 20 28 54 |...param|Ptr = (T|
|00004bc0| 72 61 63 65 50 61 72 61 | 6d 42 6c 6f 63 6b 20 2a |racePara|mBlock *|
|00004bd0| 29 20 26 28 63 74 6c 50 | 42 2d 3e 63 73 50 61 72 |) &(ctlP|B->csPar|
|00004be0| 61 6d 29 3b 0d 0d 09 2f | 2f 20 43 61 6c 6c 20 74 |am);.../|/ Call t|
|00004bf0| 68 65 20 54 72 61 63 6b | 73 20 63 6f 64 65 2e 0d |he Track|s code..|
|00004c00| 0d 09 65 72 72 6f 72 20 | 3d 20 54 72 61 63 65 45 |..error |= TraceE|
|00004c10| 6e 74 72 79 28 67 6c 6f | 62 61 6c 73 2c 20 63 73 |ntry(glo|bals, cs|
|00004c20| 43 6f 64 65 2c 20 70 61 | 72 61 6d 50 74 72 2c 20 |Code, pa|ramPtr, |
|00004c30| 64 43 74 6c 29 3b 0d 09 | 09 0d 09 72 65 74 75 72 |dCtl);..|...retur|
|00004c40| 6e 28 65 72 72 6f 72 29 | 3b 0d 09 0d 09 7d 0d 0d |n(error)|;....}..|
|00004c50| 0d 4f 53 45 72 72 20 54 | 4f 70 65 6e 28 43 6e 74 |.OSErr T|Open(Cnt|
|00004c60| 72 6c 50 61 72 61 6d 20 | 2a 63 74 6c 50 42 2c 20 |rlParam |*ctlPB, |
|00004c70| 44 43 74 6c 50 74 72 20 | 64 43 74 6c 29 0d 09 7b |DCtlPtr |dCtl)..{|
|00004c80| 0d 23 70 72 61 67 6d 61 | 20 75 6e 75 73 65 64 20 |.#pragma| unused |
|00004c90| 28 63 74 6c 50 42 29 0d | 09 72 65 67 69 73 74 65 |(ctlPB).|.registe|
|00004ca0| 72 20 4f 53 45 72 72 20 | 65 72 72 6f 72 3b 0d 09 |r OSErr |error;..|
|00004cb0| 72 65 67 69 73 74 65 72 | 20 54 72 61 63 65 47 6c |register| TraceGl|
|00004cc0| 6f 62 61 6c 73 20 2a 67 | 6c 6f 62 61 6c 73 3b 0d |obals *g|lobals;.|
|00004cd0| 0d 09 2f 2f 20 54 68 65 | 20 64 43 74 6c 53 74 6f |..// The| dCtlSto|
|00004ce0| 72 61 67 65 20 66 69 65 | 6c 64 20 69 6e 20 74 68 |rage fie|ld in th|
|00004cf0| 65 20 44 43 45 20 65 6e | 74 72 79 20 69 73 20 75 |e DCE en|try is u|
|00004d00| 73 65 64 20 74 6f 20 6b | 65 65 70 20 61 20 70 6f |sed to k|eep a po|
|00004d10| 69 6e 74 65 72 0d 09 2f | 2f 20 74 6f 20 74 68 65 |inter../|/ to the|
|00004d20| 20 67 6c 6f 62 61 6c 20 | 6d 65 6d 6f 72 79 20 62 | global |memory b|
|00004d30| 6c 6f 63 6b 2e 20 20 54 | 68 69 73 20 77 69 6c 6c |lock. T|his will|
|00004d40| 20 62 65 20 6e 69 6c 20 | 6f 6e 20 74 68 65 20 66 | be nil |on the f|
|00004d50| 69 72 73 74 20 4f 70 65 | 6e 20 63 61 6c 6c 2e 0d |irst Ope|n call..|
|00004d60| 09 0d 09 65 72 72 6f 72 | 20 3d 20 6e 6f 45 72 72 |...error| = noErr|
|00004d70| 3b 0d 09 67 6c 6f 62 61 | 6c 73 20 3d 20 28 54 72 |;..globa|ls = (Tr|
|00004d80| 61 63 65 47 6c 6f 62 61 | 6c 73 20 2a 29 20 64 43 |aceGloba|ls *) dC|
|00004d90| 74 6c 2d 3e 64 43 74 6c | 53 74 6f 72 61 67 65 3b |tl->dCtl|Storage;|
|00004da0| 0d 09 0d 09 69 66 20 28 | 67 6c 6f 62 61 6c 73 20 |....if (|globals |
|00004db0| 3d 3d 20 6e 69 6c 29 0d | 09 09 7b 0d 09 09 2f 2f |== nil).|..{...//|
|00004dc0| 20 41 6c 6c 6f 63 61 74 | 65 20 67 6c 6f 62 61 6c | Allocat|e global|
|00004dd0| 20 73 74 6f 72 61 67 65 | 20 61 73 20 61 20 6e 6f | storage| as a no|
|00004de0| 6e 2d 72 65 6c 6f 63 61 | 74 61 62 6c 65 20 62 6c |n-reloca|table bl|
|00004df0| 6f 63 6b 20 6f 6e 20 74 | 68 65 20 53 79 73 74 65 |ock on t|he Syste|
|00004e00| 6d 20 48 65 61 70 2e 2e | 2e 0d 0d 09 20 20 09 67 |m Heap..|.... .g|
|00004e10| 6c 6f 62 61 6c 73 20 3d | 20 28 54 72 61 63 65 47 |lobals =| (TraceG|
|00004e20| 6c 6f 62 61 6c 73 20 2a | 29 20 4e 65 77 50 74 72 |lobals *|) NewPtr|
|00004e30| 53 79 73 43 6c 65 61 72 | 28 73 69 7a 65 6f 66 28 |SysClear|(sizeof(|
|00004e40| 54 72 61 63 65 47 6c 6f | 62 61 6c 73 29 29 3b 0d |TraceGlo|bals));.|
|00004e50| 0d 09 09 69 66 20 28 67 | 6c 6f 62 61 6c 73 20 3d |...if (g|lobals =|
|00004e60| 3d 20 6e 69 6c 29 0d 09 | 09 09 65 72 72 6f 72 20 |= nil)..|..error |
|00004e70| 3d 20 4d 65 6d 45 72 72 | 6f 72 28 29 3b 0d 09 09 |= MemErr|or();...|
|00004e80| 65 6c 73 65 0d 09 09 09 | 7b 0d 0d 09 09 09 2f 2f |else....|{.....//|
|00004e90| 20 49 6e 69 74 69 61 6c | 69 7a 65 20 74 68 65 20 | Initial|ize the |
|00004ea0| 74 72 61 63 65 20 63 6f | 64 65 3a 0d 09 09 09 0d |trace co|de:.....|
|00004eb0| 09 09 09 49 6e 69 74 54 | 72 61 63 65 28 67 6c 6f |...InitT|race(glo|
|00004ec0| 62 61 6c 73 29 3b 0d 0d | 09 09 09 2f 2f 20 53 61 |bals);..|...// Sa|
|00004ed0| 76 65 20 61 20 70 6f 69 | 6e 74 65 72 20 74 6f 20 |ve a poi|nter to |
|00004ee0| 74 68 65 20 67 6c 6f 62 | 61 6c 73 20 69 6e 20 74 |the glob|als in t|
|00004ef0| 68 65 20 44 43 45 3a 0d | 09 09 0d 09 09 09 64 43 |he DCE:.|......dC|
|00004f00| 74 6c 2d 3e 64 43 74 6c | 53 74 6f 72 61 67 65 20 |tl->dCtl|Storage |
|00004f10| 3d 20 28 48 61 6e 64 6c | 65 29 20 67 6c 6f 62 61 |= (Handl|e) globa|
|00004f20| 6c 73 3b 0d 09 09 09 0d | 09 09 09 7d 0d 09 09 7d |ls;.....|...}...}|
|00004f30| 0d 0d 09 72 65 74 75 72 | 6e 28 65 72 72 6f 72 29 |...retur|n(error)|
|00004f40| 3b 0d 09 0d 09 7d 0d 0d | 0d 4f 53 45 72 72 20 54 |;....}..|.OSErr T|
|00004f50| 50 72 69 6d 65 28 43 6e | 74 72 6c 50 61 72 61 6d |Prime(Cn|trlParam|
|00004f60| 20 2a 63 74 6c 50 42 2c | 20 44 43 74 6c 50 74 72 | *ctlPB,| DCtlPtr|
|00004f70| 20 64 43 74 6c 29 0d 09 | 7b 0d 23 70 72 61 67 6d | dCtl)..|{.#pragm|
|00004f80| 61 20 75 6e 75 73 65 64 | 20 28 63 74 6c 50 42 2c |a unused| (ctlPB,|
|00004f90| 20 64 43 74 6c 29 0d 09 | 72 65 74 75 72 6e 28 72 | dCtl)..|return(r|
|00004fa0| 65 61 64 45 72 72 29 3b | 0d 09 7d 0d 0d 4f 53 45 |eadErr);|..}..OSE|
|00004fb0| 72 72 20 54 53 74 61 74 | 75 73 28 43 6e 74 72 6c |rr TStat|us(Cntrl|
|00004fc0| 50 61 72 61 6d 20 2a 63 | 74 6c 50 42 2c 20 44 43 |Param *c|tlPB, DC|
|00004fd0| 74 6c 50 74 72 20 64 43 | 74 6c 29 20 7b 0d 72 65 |tlPtr dC|tl) {.re|
|00004fe0| 67 69 73 74 65 72 20 4f | 53 45 72 72 20 65 72 72 |gister O|SErr err|
|00004ff0| 6f 72 3b 0d 72 65 67 69 | 73 74 65 72 20 73 68 6f |or;.regi|ster sho|
|00005000| 72 74 20 63 73 43 6f 64 | 65 3b 0d 72 65 67 69 73 |rt csCod|e;.regis|
|00005010| 74 65 72 20 54 72 61 63 | 65 50 61 72 61 6d 42 6c |ter Trac|eParamBl|
|00005020| 6f 63 6b 20 2a 70 61 72 | 61 6d 50 74 72 3b 09 0d |ock *par|amPtr;..|
|00005030| 72 65 67 69 73 74 65 72 | 20 54 72 61 63 65 47 6c |register| TraceGl|
|00005040| 6f 62 61 6c 73 20 2a 67 | 6c 6f 62 61 6c 73 3b 0d |obals *g|lobals;.|
|00005050| 09 09 0d 09 2f 2f 20 54 | 68 65 20 64 43 74 6c 53 |....// T|he dCtlS|
|00005060| 74 6f 72 61 67 65 20 66 | 69 65 6c 64 20 69 6e 20 |torage f|ield in |
|00005070| 74 68 65 20 44 43 45 20 | 65 6e 74 72 79 20 63 6f |the DCE |entry co|
|00005080| 6e 74 61 69 6e 73 20 6f | 75 72 20 67 6c 6f 62 61 |ntains o|ur globa|
|00005090| 6c 73 20 70 6f 69 6e 74 | 65 72 0d 0d 09 67 6c 6f |ls point|er...glo|
|000050a0| 62 61 6c 73 20 3d 20 28 | 54 72 61 63 65 47 6c 6f |bals = (|TraceGlo|
|000050b0| 62 61 6c 73 20 2a 29 20 | 64 43 74 6c 2d 3e 64 43 |bals *) |dCtl->dC|
|000050c0| 74 6c 53 74 6f 72 61 67 | 65 3b 0d 09 63 73 43 6f |tlStorag|e;..csCo|
|000050d0| 64 65 20 3d 20 63 74 6c | 50 42 2d 3e 63 73 43 6f |de = ctl|PB->csCo|
|000050e0| 64 65 3b 0d 09 0d 09 2f | 2f 20 54 68 65 20 54 72 |de;..../|/ The Tr|
|000050f0| 61 63 65 50 61 72 61 6d | 42 6c 6f 63 6b 20 69 73 |aceParam|Block is|
|00005100| 20 72 65 74 75 72 6e 65 | 64 20 69 6e 20 63 73 50 | returne|d in csP|
|00005110| 61 72 61 6d 3a 0d 0d 09 | 70 61 72 61 6d 50 74 72 |aram:...|paramPtr|
|00005120| 20 3d 20 28 54 72 61 63 | 65 50 61 72 61 6d 42 6c | = (Trac|eParamBl|
|00005130| 6f 63 6b 20 2a 29 20 26 | 28 63 74 6c 50 42 2d 3e |ock *) &|(ctlPB->|
|00005140| 63 73 50 61 72 61 6d 29 | 3b 0d 0d 09 65 72 72 6f |csParam)|;...erro|
|00005150| 72 20 3d 20 54 72 61 63 | 65 45 6e 74 72 79 28 67 |r = Trac|eEntry(g|
|00005160| 6c 6f 62 61 6c 73 2c 20 | 63 73 43 6f 64 65 2c 20 |lobals, |csCode, |
|00005170| 70 61 72 61 6d 50 74 72 | 2c 20 64 43 74 6c 29 3b |paramPtr|, dCtl);|
|00005180| 0d 09 09 0d 09 72 65 74 | 75 72 6e 28 65 72 72 6f |.....ret|urn(erro|
|00005190| 72 29 3b 0d 09 0d 7d 0d | 0d 0d 76 6f 69 64 20 48 |r);...}.|..void H|
|000051a0| 61 6e 64 6c 65 54 72 61 | 63 65 44 61 74 61 28 54 |andleTra|ceData(T|
|000051b0| 72 61 63 65 47 6c 6f 62 | 61 6c 73 20 2a 67 6c 6f |raceGlob|als *glo|
|000051c0| 62 61 6c 73 2c 20 63 68 | 61 72 20 64 69 61 67 49 |bals, ch|ar diagI|
|000051d0| 44 2c 20 63 68 61 72 20 | 70 61 72 74 43 6f 64 65 |D, char |partCode|
|000051e0| 2c 20 0d 09 63 68 61 72 | 20 66 6f 72 6d 61 74 49 |, ..char| formatI|
|000051f0| 44 2c 20 6c 6f 6e 67 20 | 64 61 74 61 31 2c 20 6c |D, long |data1, l|
|00005200| 6f 6e 67 20 64 61 74 61 | 32 2c 20 6c 6f 6e 67 20 |ong data|2, long |
|00005210| 64 61 74 61 33 29 3b 0d | 0d 42 6c 6f 63 6b 41 70 |data3);.|.BlockAp|
|00005220| 70 65 6e 64 28 50 74 72 | 20 73 6f 75 72 63 65 50 |pend(Ptr| sourceP|
|00005230| 74 72 2c 20 53 61 66 65 | 4d 65 6d 42 6c 6f 63 6b |tr, Safe|MemBlock|
|00005240| 20 2a 4d 65 6d 42 6c 6f | 63 6b 2c 20 6c 6f 6e 67 | *MemBlo|ck, long|
|00005250| 20 72 65 71 75 65 73 74 | 53 69 7a 65 29 0d 7b 0d | request|Size).{.|
|00005260| 72 65 67 69 73 74 65 72 | 20 6c 6f 6e 67 09 73 69 |register| long.si|
|00005270| 7a 65 4c 65 66 74 3b 0d | 72 65 67 69 73 74 65 72 |zeLeft;.|register|
|00005280| 20 73 68 6f 72 74 20 72 | 65 73 75 6c 74 20 3d 20 | short r|esult = |
|00005290| 30 3b 0d 0d 09 73 69 7a | 65 4c 65 66 74 20 20 3d |0;...siz|eLeft =|
|000052a0| 20 28 6c 6f 6e 67 29 20 | 28 4d 65 6d 42 6c 6f 63 | (long) |(MemBloc|
|000052b0| 6b 2d 3e 45 6e 64 20 2d | 20 4d 65 6d 42 6c 6f 63 |k->End -| MemBloc|
|000052c0| 6b 2d 3e 4d 61 72 6b 29 | 3b 0d 0d 09 69 66 20 28 |k->Mark)|;...if (|
|000052d0| 73 69 7a 65 4c 65 66 74 | 2d 31 30 20 3c 20 72 65 |sizeLeft|-10 < re|
|000052e0| 71 75 65 73 74 53 69 7a | 65 29 20 0d 09 09 7b 0d |questSiz|e) ...{.|
|000052f0| 09 09 09 72 65 71 75 65 | 73 74 53 69 7a 65 20 3d |...reque|stSize =|
|00005300| 20 73 69 7a 65 4c 65 66 | 74 20 2d 31 3b 0d 09 09 | sizeLef|t -1;...|
|00005310| 09 72 65 73 75 6c 74 20 | 3d 20 6d 65 6d 53 43 45 |.result |= memSCE|
|00005320| 72 72 3b 09 20 2f 2f 20 | 6d 65 6d 6f 72 79 20 73 |rr;. // |memory s|
|00005330| 69 7a 65 20 63 68 65 63 | 6b 2e 2e 2e 0d 09 09 7d |ize chec|k......}|
|00005340| 0d 0d 09 42 6c 6f 63 6b | 4d 6f 76 65 28 73 6f 75 |...Block|Move(sou|
|00005350| 72 63 65 50 74 72 2c 4d | 65 6d 42 6c 6f 63 6b 2d |rcePtr,M|emBlock-|
|00005360| 3e 4d 61 72 6b 2c 20 72 | 65 71 75 65 73 74 53 69 |>Mark, r|equestSi|
|00005370| 7a 65 29 3b 0d 09 4d 65 | 6d 42 6c 6f 63 6b 2d 3e |ze);..Me|mBlock->|
|00005380| 4d 61 72 6b 20 2b 3d 20 | 72 65 71 75 65 73 74 53 |Mark += |requestS|
|00005390| 69 7a 65 3b 0d 09 72 65 | 74 75 72 6e 20 72 65 73 |ize;..re|turn res|
|000053a0| 75 6c 74 3b 0d 7d 0d 0d | 2f 2a 20 54 68 69 73 20 |ult;.}..|/* This |
|000053b0| 69 73 20 74 68 65 20 65 | 6e 74 72 79 20 70 6f 69 |is the e|ntry poi|
|000053c0| 6e 74 20 66 6f 72 20 54 | 72 61 63 65 20 63 61 6c |nt for T|race cal|
|000053d0| 6c 73 20 66 72 6f 6d 20 | 74 68 65 20 74 61 72 67 |ls from |the targ|
|000053e0| 65 74 20 64 72 69 76 65 | 72 2e 0d 2a 2a 20 54 68 |et drive|r..** Th|
|000053f0| 69 73 20 72 6f 75 74 69 | 6e 65 20 69 73 20 6e 6f |is routi|ne is no|
|00005400| 74 20 63 61 6c 6c 65 64 | 20 66 72 6f 6d 20 74 68 |t called| from th|
|00005410| 65 20 64 72 69 76 65 72 | 2d 2d 20 69 74 20 69 73 |e driver|-- it is|
|00005420| 20 63 61 6c 6c 65 64 20 | 62 79 20 74 68 65 20 74 | called |by the t|
|00005430| 61 72 67 65 74 20 64 72 | 69 76 65 72 2e 0d 2a 2a |arget dr|iver..**|
|00005440| 20 49 74 20 63 61 6e 20 | 61 63 63 65 73 73 20 74 | It can |access t|
|00005450| 68 69 73 20 64 72 69 76 | 65 72 27 73 20 67 6c 6f |his driv|er's glo|
|00005460| 62 61 6c 73 20 62 65 63 | 61 75 73 65 20 74 68 65 |bals bec|ause the|
|00005470| 20 74 61 72 67 65 74 20 | 64 72 69 76 65 72 20 70 | target |driver p|
|00005480| 61 73 73 65 73 20 74 68 | 65 6d 20 69 6e 2e 0d 2a |asses th|em in..*|
|00005490| 2f 0d 70 61 73 63 61 6c | 20 76 6f 69 64 20 54 72 |/.pascal| void Tr|
|000054a0| 61 63 65 50 72 6f 63 28 | 6c 6f 6e 67 20 72 65 66 |aceProc(|long ref|
|000054b0| 63 6f 6e 2c 20 63 68 61 | 72 20 64 69 61 67 49 44 |con, cha|r diagID|
|000054c0| 2c 20 63 68 61 72 20 70 | 61 72 74 43 6f 64 65 2c |, char p|artCode,|
|000054d0| 0d 09 63 68 61 72 20 66 | 6f 72 6d 61 74 49 44 2c |..char f|ormatID,|
|000054e0| 20 6c 6f 6e 67 20 64 61 | 74 61 31 2c 20 6c 6f 6e | long da|ta1, lon|
|000054f0| 67 20 64 61 74 61 32 2c | 20 6c 6f 6e 67 20 64 61 |g data2,| long da|
|00005500| 74 61 33 29 0d 7b 0d 72 | 65 67 69 73 74 65 72 20 |ta3).{.r|egister |
|00005510| 54 72 61 63 65 47 6c 6f | 62 61 6c 73 20 2a 67 6c |TraceGlo|bals *gl|
|00005520| 6f 62 61 6c 73 3b 0d 72 | 65 67 69 73 74 65 72 20 |obals;.r|egister |
|00005530| 42 6f 6f 6c 65 61 6e 20 | 09 6f 6b 4c 6f 63 6b 65 |Boolean |.okLocke|
|00005540| 64 3b 0d 72 65 67 69 73 | 74 65 72 20 42 6f 6f 6c |d;.regis|ter Bool|
|00005550| 65 61 6e 09 42 72 65 61 | 6b 4f 6e 45 78 69 74 20 |ean.Brea|kOnExit |
|00005560| 3d 20 66 61 6c 73 65 3b | 09 0d 0d 09 67 6c 6f 62 |= false;|....glob|
|00005570| 61 6c 73 20 3d 20 28 54 | 72 61 63 65 47 6c 6f 62 |als = (T|raceGlob|
|00005580| 61 6c 73 20 2a 29 72 65 | 66 63 6f 6e 3b 09 2f 2f |als *)re|fcon;.//|
|00005590| 20 73 65 74 20 75 70 20 | 64 72 69 76 65 72 20 67 | set up |driver g|
|000055a0| 6c 6f 62 61 6c 73 0d 0d | 09 69 66 20 28 64 69 61 |lobals..|.if (dia|
|000055b0| 67 49 44 20 3c 20 31 32 | 38 29 09 09 2f 2f 20 76 |gID < 12|8)..// v|
|000055c0| 61 69 6c 64 20 64 69 61 | 67 49 44 27 73 20 72 61 |aild dia|gID's ra|
|000055d0| 6e 67 65 20 66 72 6f 6d | 20 30 20 74 6f 20 31 32 |nge from| 0 to 12|
|000055e0| 37 2e 2e 2e 20 0d 09 09 | 7b 09 0d 09 09 09 2f 2f |7... ...|{.....//|
|000055f0| 20 43 68 65 63 6b 20 74 | 6f 20 73 65 65 20 69 66 | Check t|o see if|
|00005600| 20 74 68 65 72 65 20 73 | 68 6f 75 6c 64 20 62 65 | there s|hould be|
|00005610| 20 61 20 62 72 65 61 6b | 20 6f 6e 20 65 78 69 74 | a break| on exit|
|00005620| 20 28 62 72 65 61 6b 70 | 6f 69 6e 74 20 77 61 73 | (breakp|oint was|
|00005630| 20 73 65 74 29 2e 0d 09 | 09 09 42 72 65 61 6b 4f | set)...|..BreakO|
|00005640| 6e 45 78 69 74 20 3d 20 | 42 69 74 54 73 74 28 28 |nExit = |BitTst((|
|00005650| 50 74 72 29 67 6c 6f 62 | 61 6c 73 2d 3e 66 42 72 |Ptr)glob|als->fBr|
|00005660| 65 61 6b 4d 61 73 6b 2c | 28 6c 6f 6e 67 29 64 69 |eakMask,|(long)di|
|00005670| 61 67 49 44 29 3b 0d 09 | 09 09 0d 09 09 09 0d 09 |agID);..|........|
|00005680| 09 09 2f 2f 20 20 43 68 | 65 63 6b 20 74 6f 20 73 |..// Ch|eck to s|
|00005690| 65 65 20 74 68 65 20 69 | 6e 66 6f 72 6d 61 74 69 |ee the i|nformati|
|000056a0| 6f 6e 20 70 61 73 73 65 | 64 20 73 68 6f 75 6c 64 |on passe|d should|
|000056b0| 20 62 65 20 6c 6f 67 67 | 65 64 2e 20 20 0d 09 09 | be logg|ed. ...|
|000056c0| 09 69 66 20 28 42 69 74 | 54 73 74 28 28 50 74 72 |.if (Bit|Tst((Ptr|
|000056d0| 29 67 6c 6f 62 61 6c 73 | 2d 3e 66 54 72 61 63 65 |)globals|->fTrace|
|000056e0| 4d 61 73 6b 2c 20 28 6c | 6f 6e 67 29 64 69 61 67 |Mask, (l|ong)diag|
|000056f0| 49 44 29 29 0d 09 09 09 | 7b 0d 09 09 09 09 2f 2f |ID))....|{.....//|
|00005700| 20 54 68 65 20 74 72 61 | 63 65 20 70 6f 69 6e 74 | The tra|ce point|
|00005710| 20 77 61 73 20 73 65 74 | 2d 20 63 68 65 63 6b 20 | was set|- check |
|00005720| 74 6f 20 73 65 65 20 69 | 66 20 74 68 65 20 62 75 |to see i|f the bu|
|00005730| 66 66 65 72 20 65 78 69 | 73 74 73 20 61 6e 64 20 |ffer exi|sts and |
|00005740| 69 73 20 72 65 61 64 79 | 2e 0d 09 09 09 09 69 66 |is ready|......if|
|00005750| 20 28 67 6c 6f 62 61 6c | 73 2d 3e 66 42 75 66 66 | (global|s->fBuff|
|00005760| 65 72 45 6e 61 62 6c 65 | 64 29 20 09 09 2f 2f 20 |erEnable|d) ..// |
|00005770| 54 68 65 72 65 20 69 73 | 20 61 20 62 75 66 66 65 |There is| a buffe|
|00005780| 72 20 74 6f 20 77 72 69 | 74 65 20 74 6f 0d 09 09 |r to wri|te to...|
|00005790| 09 09 7b 0d 09 09 09 09 | 09 6f 6b 4c 6f 63 6b 65 |..{.....|.okLocke|
|000057a0| 64 20 3d 20 55 54 4c 6f | 63 6b 28 26 28 67 6c 6f |d = UTLo|ck(&(glo|
|000057b0| 62 61 6c 73 2d 3e 66 54 | 72 61 63 65 4c 6f 63 6b |bals->fT|raceLock|
|000057c0| 29 29 3b 20 2f 2f 20 74 | 65 73 74 20 61 6e 64 20 |)); // t|est and |
|000057d0| 73 65 74 20 66 6c 61 67 | 0d 09 09 09 0d 09 09 09 |set flag|........|
|000057e0| 09 09 69 66 20 28 21 6f | 6b 4c 6f 63 6b 65 64 29 |..if (!o|kLocked)|
|000057f0| 20 2f 2f 20 49 66 20 74 | 68 69 73 20 74 72 61 63 | // If t|his trac|
|00005800| 65 20 72 65 71 75 65 73 | 74 20 77 61 73 20 6c 6f |e reques|t was lo|
|00005810| 63 6b 65 64 20 6f 75 74 | 2c 20 74 68 65 6e 20 73 |cked out|, then s|
|00005820| 65 74 20 6c 6f 63 6b 65 | 64 2d 6f 75 74 20 66 6c |et locke|d-out fl|
|00005830| 61 67 0d 09 09 09 09 09 | 09 67 6c 6f 62 61 6c 73 |ag......|.globals|
|00005840| 2d 3e 66 4c 6f 63 6b 65 | 64 4f 75 74 46 6c 61 67 |->fLocke|dOutFlag|
|00005850| 20 3d 20 74 72 75 65 3b | 09 2f 2f 20 6f 6e 65 20 | = true;|.// one |
|00005860| 74 72 61 63 69 6e 67 20 | 72 65 71 75 65 73 74 20 |tracing |request |
|00005870| 69 6e 74 65 72 72 75 70 | 74 65 64 20 61 6e 6f 74 |interrup|ted anot|
|00005880| 68 65 72 0d 09 09 09 09 | 09 65 6c 73 65 0d 09 09 |her.....|.else...|
|00005890| 09 09 09 09 48 61 6e 64 | 6c 65 54 72 61 63 65 44 |....Hand|leTraceD|
|000058a0| 61 74 61 28 67 6c 6f 62 | 61 6c 73 2c 20 64 69 61 |ata(glob|als, dia|
|000058b0| 67 49 44 2c 20 70 61 72 | 74 43 6f 64 65 2c 20 66 |gID, par|tCode, f|
|000058c0| 6f 72 6d 61 74 49 44 2c | 20 64 61 74 61 31 2c 20 |ormatID,| data1, |
|000058d0| 64 61 74 61 32 2c 20 64 | 61 74 61 33 29 3b 0d 09 |data2, d|ata3);..|
|000058e0| 09 09 09 7d 0d 09 09 09 | 0d 09 09 09 7d 0d 09 09 |...}....|....}...|
|000058f0| 7d 20 0d 09 09 0d 2f 2f | 20 20 48 61 6e 64 6c 65 |} ....//| Handle|
|00005900| 20 74 68 65 20 62 72 65 | 61 6b 70 6f 69 6e 74 2c | the bre|akpoint,|
|00005910| 20 69 66 20 61 6e 79 2e | 0d 09 69 66 20 28 42 72 | if any.|..if (Br|
|00005920| 65 61 6b 4f 6e 45 78 69 | 74 29 0d 09 7b 0d 09 09 |eakOnExi|t)..{...|
|00005930| 69 66 20 28 67 6c 6f 62 | 61 6c 73 2d 3e 66 42 72 |if (glob|als->fBr|
|00005940| 65 61 6b 4f 6e 63 65 54 | 68 65 6e 43 6c 65 61 72 |eakOnceT|henClear|
|00005950| 29 0d 09 09 7b 0d 09 09 | 09 42 69 74 43 6c 72 28 |)...{...|.BitClr(|
|00005960| 28 50 74 72 29 67 6c 6f | 62 61 6c 73 2d 3e 66 42 |(Ptr)glo|bals->fB|
|00005970| 72 65 61 6b 4d 61 73 6b | 2c 28 6c 6f 6e 67 29 64 |reakMask|,(long)d|
|00005980| 69 61 67 49 44 29 3b 0d | 09 09 09 67 6c 6f 62 61 |iagID);.|...globa|
|00005990| 6c 73 2d 3e 66 44 65 62 | 75 67 4d 61 72 6b 55 6e |ls->fDeb|ugMarkUn|
|000059a0| 73 65 74 20 3d 20 74 72 | 75 65 3b 09 09 2f 2f 20 |set = tr|ue;..// |
|000059b0| 53 69 67 6e 61 6c 20 63 | 64 65 76 20 74 68 61 74 |Signal c|dev that|
|000059c0| 20 64 65 62 75 67 20 6d | 61 72 6b 20 77 61 73 20 | debug m|ark was |
|000059d0| 74 75 72 6e 65 64 20 6f | 66 66 0d 09 09 09 44 65 |turned o|ff....De|
|000059e0| 62 75 67 53 74 72 28 22 | 5c 70 54 72 61 63 6b 73 |bugStr("|\pTracks|
|000059f0| 20 55 73 65 72 20 42 72 | 65 61 6b 70 6f 69 6e 74 | User Br|eakpoint|
|00005a00| 20 28 4f 6e 63 65 29 22 | 29 3b 0d 09 09 7d 0d 09 | (Once)"|);...}..|
|00005a10| 09 65 6c 73 65 0d 09 09 | 09 44 65 62 75 67 53 74 |.else...|.DebugSt|
|00005a20| 72 28 22 5c 70 54 72 61 | 63 6b 73 20 55 73 65 72 |r("\pTra|cks User|
|00005a30| 20 42 72 65 61 6b 70 6f | 69 6e 74 22 29 3b 0d 09 | Breakpo|int");..|
|00005a40| 7d 0d 09 72 65 74 75 72 | 6e 3b 0d 7d 0d 2f 2f 20 |}..retur|n;.}.// |
|00005a50| 44 69 73 70 61 74 63 68 | 20 69 6e 63 6f 6d 69 6e |Dispatch| incomin|
|00005a60| 67 20 6d 65 73 73 61 67 | 65 73 20 66 72 6f 6d 20 |g messag|es from |
|00005a70| 63 6f 6e 74 72 6f 6c 20 | 61 6e 64 20 73 74 61 74 |control |and stat|
|00005a80| 75 73 20 63 61 6c 6c 73 | 2e 0d 70 61 73 63 61 6c |us calls|..pascal|
|00005a90| 20 73 68 6f 72 74 20 54 | 72 61 63 65 45 6e 74 72 | short T|raceEntr|
|00005aa0| 79 28 54 72 61 63 65 47 | 6c 6f 62 61 6c 73 20 2a |y(TraceG|lobals *|
|00005ab0| 67 6c 6f 62 61 6c 73 2c | 20 73 68 6f 72 74 20 63 |globals,| short c|
|00005ac0| 73 43 6f 64 65 2c 20 54 | 72 61 63 65 50 61 72 61 |sCode, T|racePara|
|00005ad0| 6d 42 6c 6f 63 6b 20 2a | 70 61 72 61 6d 50 74 72 |mBlock *|paramPtr|
|00005ae0| 2c 20 44 43 74 6c 50 74 | 72 20 64 43 74 6c 29 20 |, DCtlPt|r dCtl) |
|00005af0| 0d 20 7b 0d 72 65 67 69 | 73 74 65 72 20 73 68 6f |. {.regi|ster sho|
|00005b00| 72 74 20 72 65 73 75 6c | 74 3b 0d 41 75 74 6f 54 |rt resul|t;.AutoT|
|00005b10| 72 61 63 65 52 65 63 20 | 2a 61 74 72 3b 0d 0d 09 |raceRec |*atr;...|
|00005b20| 72 65 73 75 6c 74 20 3d | 20 6e 6f 45 72 72 3b 0d |result =| noErr;.|
|00005b30| 0d 09 67 6c 6f 62 61 6c | 73 2d 3e 66 54 72 61 63 |..global|s->fTrac|
|00005b40| 65 4c 6f 63 6b 20 3d 20 | 74 72 75 65 3b 0d 09 0d |eLock = |true;...|
|00005b50| 09 73 77 69 74 63 68 20 | 28 63 73 43 6f 64 65 29 |.switch |(csCode)|
|00005b60| 0d 09 09 7b 0d 09 09 0d | 09 20 20 63 61 73 65 20 |...{....|. case |
|00005b70| 6b 53 65 74 54 72 61 63 | 65 4f 6e 6c 69 6e 65 3a |kSetTrac|eOnline:|
|00005b80| 0d 09 20 09 0d 09 09 72 | 65 73 75 6c 74 20 3d 20 |.. ....r|esult = |
|00005b90| 53 65 74 54 72 61 63 65 | 4f 6e 6c 69 6e 65 28 67 |SetTrace|Online(g|
|00005ba0| 6c 6f 62 61 6c 73 2c 20 | 28 63 68 61 72 20 2a 29 |lobals, |(char *)|
|00005bb0| 70 61 72 61 6d 50 74 72 | 29 3b 09 2f 2a 20 54 68 |paramPtr|);./* Th|
|00005bc0| 65 20 6e 61 6d 65 20 6f | 66 20 74 68 65 20 74 61 |e name o|f the ta|
|00005bd0| 72 67 65 74 20 64 72 69 | 76 65 72 20 69 73 20 69 |rget dri|ver is i|
|00005be0| 6e 20 70 61 72 61 6d 50 | 74 72 20 28 61 20 70 61 |n paramP|tr (a pa|
|00005bf0| 73 63 61 6c 20 73 74 72 | 69 6e 67 29 20 2a 2f 0d |scal str|ing) */.|
|00005c00| 09 09 62 72 65 61 6b 3b | 0d 0d 09 20 20 63 61 73 |..break;|... cas|
|00005c10| 65 20 6b 53 65 74 54 72 | 61 63 65 4f 66 66 6c 69 |e kSetTr|aceOffli|
|00005c20| 6e 65 3a 0d 09 09 72 65 | 73 75 6c 74 20 3d 20 53 |ne:...re|sult = S|
|00005c30| 65 74 54 72 61 63 65 4f | 66 66 6c 69 6e 65 28 67 |etTraceO|ffline(g|
|00005c40| 6c 6f 62 61 6c 73 29 3b | 0d 09 09 62 72 65 61 6b |lobals);|...break|
|00005c50| 3b 0d 0d 09 20 2f 2a 2a | 2a 2a 20 4e 4f 20 4c 4f |;... /**|** NO LO|
|00005c60| 4e 47 45 52 20 55 53 45 | 44 0d 09 20 20 63 61 73 |NGER USE|D.. cas|
|00005c70| 65 20 6b 54 72 61 63 65 | 52 65 61 64 3a 0d 09 09 |e kTrace|Read:...|
|00005c80| 72 65 73 75 6c 74 20 3d | 20 52 65 61 64 54 72 61 |result =| ReadTra|
|00005c90| 63 65 28 67 6c 6f 62 61 | 6c 73 2c 20 70 61 72 61 |ce(globa|ls, para|
|00005ca0| 6d 50 74 72 29 3b 0d 09 | 09 62 72 65 61 6b 3b 0d |mPtr);..|.break;.|
|00005cb0| 09 20 2a 2a 2a 2a 2f 0d | 0d 09 20 20 63 61 73 65 |. ****/.|.. case|
|00005cc0| 20 6b 41 75 74 6f 54 72 | 61 63 65 3a 0d 09 20 20 | kAutoTr|ace:.. |
|00005cd0| 09 61 74 72 20 3d 20 28 | 41 75 74 6f 54 72 61 63 |.atr = (|AutoTrac|
|00005ce0| 65 52 65 63 20 2a 29 20 | 70 61 72 61 6d 50 74 72 |eRec *) |paramPtr|
|00005cf0| 3b 0d 09 09 54 72 61 63 | 65 50 72 6f 63 28 28 6c |;...Trac|eProc((l|
|00005d00| 6f 6e 67 29 67 6c 6f 62 | 61 6c 73 2c 20 61 74 72 |ong)glob|als, atr|
|00005d10| 2d 3e 64 69 61 67 49 44 | 2c 20 61 74 72 2d 3e 70 |->diagID|, atr->p|
|00005d20| 61 72 74 43 6f 64 65 2c | 20 61 74 72 2d 3e 66 6f |artCode,| atr->fo|
|00005d30| 72 6d 61 74 49 44 2c 20 | 61 74 72 2d 3e 64 61 74 |rmatID, |atr->dat|
|00005d40| 61 31 2c 20 61 74 72 2d | 3e 64 61 74 61 32 2c 20 |a1, atr-|>data2, |
|00005d50| 61 74 72 2d 3e 64 61 74 | 61 33 29 3b 0d 09 09 0d |atr->dat|a3);....|
|00005d60| 09 09 62 72 65 61 6b 3b | 0d 0d 09 09 0d 09 20 20 |..break;|...... |
|00005d70| 63 61 73 65 20 6b 45 6e | 61 62 6c 65 54 72 61 63 |case kEn|ableTrac|
|00005d80| 65 42 75 66 66 65 72 3a | 0d 09 09 72 65 73 75 6c |eBuffer:|...resul|
|00005d90| 74 20 3d 20 45 6e 61 62 | 6c 65 54 72 61 63 65 42 |t = Enab|leTraceB|
|00005da0| 75 66 66 65 72 28 67 6c | 6f 62 61 6c 73 2c 20 70 |uffer(gl|obals, p|
|00005db0| 61 72 61 6d 50 74 72 29 | 3b 0d 09 09 62 72 65 61 |aramPtr)|;...brea|
|00005dc0| 6b 3b 0d 09 09 0d 09 20 | 20 63 61 73 65 20 6b 44 |k;..... | case kD|
|00005dd0| 69 73 61 62 6c 65 54 72 | 61 63 65 42 75 66 66 65 |isableTr|aceBuffe|
|00005de0| 72 3a 0d 09 09 72 65 73 | 75 6c 74 20 3d 20 44 69 |r:...res|ult = Di|
|00005df0| 73 61 62 6c 65 54 72 61 | 63 65 42 75 66 66 65 72 |sableTra|ceBuffer|
|00005e00| 28 67 6c 6f 62 61 6c 73 | 29 3b 0d 09 09 62 72 65 |(globals|);...bre|
|00005e10| 61 6b 3b 0d 0d 09 20 20 | 63 61 73 65 20 6b 53 65 |ak;... |case kSe|
|00005e20| 74 54 72 61 63 65 46 69 | 6c 65 4e 61 6d 65 3a 0d |tTraceFi|leName:.|
|00005e30| 09 09 72 65 73 75 6c 74 | 20 3d 20 53 65 74 54 72 |..result| = SetTr|
|00005e40| 61 63 65 46 69 6c 65 4e | 61 6d 65 28 67 6c 6f 62 |aceFileN|ame(glob|
|00005e50| 61 6c 73 2c 20 70 61 72 | 61 6d 50 74 72 29 3b 0d |als, par|amPtr);.|
|00005e60| 09 09 62 72 65 61 6b 3b | 0d 09 09 0d 09 20 20 63 |..break;|..... c|
|00005e70| 61 73 65 20 6b 44 69 73 | 61 62 6c 65 54 72 61 63 |ase kDis|ableTrac|
|00005e80| 65 46 69 6c 65 3a 0d 09 | 09 72 65 73 75 6c 74 20 |eFile:..|.result |
|00005e90| 3d 20 44 69 73 61 62 6c | 65 54 72 61 63 65 46 69 |= Disabl|eTraceFi|
|00005ea0| 6c 65 28 67 6c 6f 62 61 | 6c 73 29 3b 0d 09 09 62 |le(globa|ls);...b|
|00005eb0| 72 65 61 6b 3b 0d 09 09 | 0d 09 20 20 63 61 73 65 |reak;...|.. case|
|00005ec0| 20 6b 57 72 69 74 65 54 | 72 61 63 65 42 75 66 66 | kWriteT|raceBuff|
|00005ed0| 65 72 3a 0d 09 09 72 65 | 73 75 6c 74 20 3d 20 57 |er:...re|sult = W|
|00005ee0| 72 69 74 65 54 72 61 63 | 65 42 75 66 66 65 72 28 |riteTrac|eBuffer(|
|00005ef0| 67 6c 6f 62 61 6c 73 29 | 3b 0d 09 09 62 72 65 61 |globals)|;...brea|
|00005f00| 6b 3b 0d 0d 09 20 20 63 | 61 73 65 20 6b 53 65 74 |k;... c|ase kSet|
|00005f10| 41 75 74 6f 57 72 69 74 | 65 4f 6e 3a 0d 09 20 20 |AutoWrit|eOn:.. |
|00005f20| 09 67 6c 6f 62 61 6c 73 | 2d 3e 66 41 75 74 6f 6d |.globals|->fAutom|
|00005f30| 61 74 69 63 57 72 69 74 | 65 20 3d 20 74 72 75 65 |aticWrit|e = true|
|00005f40| 3b 0d 09 09 42 69 74 53 | 65 74 28 28 50 74 72 29 |;...BitS|et((Ptr)|
|00005f50| 20 26 64 43 74 6c 2d 3e | 64 43 74 6c 46 6c 61 67 | &dCtl->|dCtlFlag|
|00005f60| 73 2c 20 32 29 3b 20 20 | 20 20 20 20 20 20 2f 2a |s, 2); | /*|
|00005f70| 20 73 65 74 20 62 69 74 | 20 35 2f 64 4e 65 65 64 | set bit| 5/dNeed|
|00005f80| 54 69 6d 65 20 62 69 74 | 2e 49 4d 20 49 2d 34 37 |Time bit|.IM I-47|
|00005f90| 31 2a 2f 0d 09 09 62 72 | 65 61 6b 3b 0d 0d 09 20 |1*/...br|eak;... |
|00005fa0| 20 63 61 73 65 20 6b 53 | 65 74 41 75 74 6f 57 72 | case kS|etAutoWr|
|00005fb0| 69 74 65 4f 66 66 3a 0d | 09 20 20 09 67 6c 6f 62 |iteOff:.|. .glob|
|00005fc0| 61 6c 73 2d 3e 66 41 75 | 74 6f 6d 61 74 69 63 57 |als->fAu|tomaticW|
|00005fd0| 72 69 74 65 20 3d 20 66 | 61 6c 73 65 3b 0d 09 09 |rite = f|alse;...|
|00005fe0| 42 69 74 43 6c 72 28 28 | 50 74 72 29 20 26 64 43 |BitClr((|Ptr) &dC|
|00005ff0| 74 6c 2d 3e 64 43 74 6c | 46 6c 61 67 73 2c 20 32 |tl->dCtl|Flags, 2|
|00006000| 29 3b 20 20 20 20 20 20 | 20 20 2f 2a 20 43 6c 65 |); | /* Cle|
|00006010| 61 72 20 62 69 74 20 35 | 2f 64 4e 65 65 64 54 69 |ar bit 5|/dNeedTi|
|00006020| 6d 65 20 62 69 74 2e 20 | 2a 2f 0d 09 09 62 72 65 |me bit. |*/...bre|
|00006030| 61 6b 3b 0d 0d 09 20 20 | 63 61 73 65 20 6b 44 6f |ak;... |case kDo|
|00006040| 50 65 72 69 6f 64 69 63 | 54 69 6d 65 3a 0d 09 20 |Periodic|Time:.. |
|00006050| 20 09 69 66 20 28 20 28 | 67 6c 6f 62 61 6c 73 2d | .if ( (|globals-|
|00006060| 3e 66 42 75 66 66 65 72 | 45 6e 61 62 6c 65 64 29 |>fBuffer|Enabled)|
|00006070| 20 26 26 20 0d 09 09 09 | 20 28 67 6c 6f 62 61 6c | && ....| (global|
|00006080| 73 2d 3e 66 46 69 6c 65 | 45 6e 61 62 6c 65 64 29 |s->fFile|Enabled)|
|00006090| 20 26 26 20 0d 09 09 09 | 20 28 67 6c 6f 62 61 6c | && ....| (global|
|000060a0| 73 2d 3e 66 41 75 74 6f | 6d 61 74 69 63 57 72 69 |s->fAuto|maticWri|
|000060b0| 74 65 29 20 29 0d 09 09 | 09 72 65 73 75 6c 74 20 |te) )...|.result |
|000060c0| 3d 20 57 72 69 74 65 54 | 72 61 63 65 42 75 66 66 |= WriteT|raceBuff|
|000060d0| 65 72 28 67 6c 6f 62 61 | 6c 73 29 3b 0d 09 09 62 |er(globa|ls);...b|
|000060e0| 72 65 61 6b 3b 0d 0d 09 | 20 20 63 61 73 65 20 6b |reak;...| case k|
|000060f0| 47 65 74 54 72 61 63 65 | 53 74 61 74 75 73 3a 0d |GetTrace|Status:.|
|00006100| 09 09 72 65 73 75 6c 74 | 20 3d 20 47 65 74 54 72 |..result| = GetTr|
|00006110| 61 63 65 53 74 61 74 75 | 73 28 67 6c 6f 62 61 6c |aceStatu|s(global|
|00006120| 73 2c 20 70 61 72 61 6d | 50 74 72 29 3b 0d 09 09 |s, param|Ptr);...|
|00006130| 62 72 65 61 6b 3b 0d 0d | 09 20 20 63 61 73 65 20 |break;..|. case |
|00006140| 6b 47 65 74 54 72 61 63 | 65 50 72 6f 63 3a 0d 09 |kGetTrac|eProc:..|
|00006150| 09 72 65 73 75 6c 74 20 | 3d 20 47 65 74 54 72 61 |.result |= GetTra|
|00006160| 63 65 50 72 6f 63 28 67 | 6c 6f 62 61 6c 73 2c 20 |ceProc(g|lobals, |
|00006170| 70 61 72 61 6d 50 74 72 | 29 3b 0d 09 09 62 72 65 |paramPtr|);...bre|
|00006180| 61 6b 3b 0d 09 20 09 0d | 09 09 63 61 73 65 09 6b |ak;.. ..|..case.k|
|00006190| 53 65 6e 64 43 64 65 76 | 42 72 65 61 6b 4d 61 73 |SendCdev|BreakMas|
|000061a0| 6b 3a 0d 09 09 63 61 73 | 65 09 6b 53 65 6e 64 43 |k:...cas|e.kSendC|
|000061b0| 64 65 76 54 72 61 63 65 | 4d 61 73 6b 3a 0d 09 09 |devTrace|Mask:...|
|000061c0| 72 65 73 75 6c 74 20 3d | 20 53 65 6e 64 4d 61 73 |result =| SendMas|
|000061d0| 6b 54 6f 43 64 65 76 28 | 67 6c 6f 62 61 6c 73 2c |kToCdev(|globals,|
|000061e0| 70 61 72 61 6d 50 74 72 | 2c 63 73 43 6f 64 65 29 |paramPtr|,csCode)|
|000061f0| 3b 0d 09 09 09 62 72 65 | 61 6b 3b 0d 09 09 63 61 |;....bre|ak;...ca|
|00006200| 73 65 09 6b 47 65 74 43 | 64 65 76 42 72 65 61 6b |se.kGetC|devBreak|
|00006210| 4d 61 73 6b 3a 0d 09 09 | 63 61 73 65 09 6b 47 65 |Mask:...|case.kGe|
|00006220| 74 43 64 65 76 54 72 61 | 63 65 4d 61 73 6b 3a 0d |tCdevTra|ceMask:.|
|00006230| 09 09 72 65 73 75 6c 74 | 20 3d 20 47 65 74 4d 61 |..result| = GetMa|
|00006240| 73 6b 46 72 6f 6d 43 44 | 45 56 28 67 6c 6f 62 61 |skFromCD|EV(globa|
|00006250| 6c 73 2c 70 61 72 61 6d | 50 74 72 2c 63 73 43 6f |ls,param|Ptr,csCo|
|00006260| 64 65 29 3b 0d 09 09 09 | 62 72 65 61 6b 3b 0d 09 |de);....|break;..|
|00006270| 09 63 61 73 65 09 6b 52 | 65 73 65 74 45 4f 46 3a |.case.kR|esetEOF:|
|00006280| 09 09 2f 2f 20 52 65 73 | 65 74 20 74 68 65 20 54 |..// Res|et the T|
|00006290| 72 61 63 65 2e 6f 75 74 | 66 69 6c 65 20 74 6f 20 |race.out|file to |
|000062a0| 7a 65 72 6f 20 62 79 74 | 65 73 20 69 6e 20 6c 65 |zero byt|es in le|
|000062b0| 6e 67 74 68 0d 09 09 72 | 65 73 75 6c 74 20 3d 20 |ngth...r|esult = |
|000062c0| 52 65 73 65 74 45 4f 46 | 28 67 6c 6f 62 61 6c 73 |ResetEOF|(globals|
|000062d0| 29 3b 0d 09 09 09 62 72 | 65 61 6b 3b 0d 09 09 09 |);....br|eak;....|
|000062e0| 0d 09 09 63 61 73 65 09 | 6b 43 6c 65 61 72 54 72 |...case.|kClearTr|
|000062f0| 61 63 65 42 75 66 66 65 | 72 3a 09 09 2f 2f 20 43 |aceBuffe|r:..// C|
|00006300| 6c 65 61 72 20 74 68 65 | 20 62 75 66 66 65 72 2d |lear the| buffer-|
|00006310| 0d 09 09 72 65 73 75 6c | 74 20 3d 20 43 6c 65 61 |...resul|t = Clea|
|00006320| 72 54 72 61 63 65 42 75 | 66 66 65 72 28 67 6c 6f |rTraceBu|ffer(glo|
|00006330| 62 61 6c 73 29 3b 0d 09 | 09 09 62 72 65 61 6b 3b |bals);..|..break;|
|00006340| 0d 09 09 09 0d 09 09 63 | 61 73 65 20 6b 53 74 61 |.......c|ase kSta|
|00006350| 72 74 65 64 46 72 6f 6d | 49 6e 69 74 3a 0d 09 09 |rtedFrom|Init:...|
|00006360| 09 67 6c 6f 62 61 6c 73 | 2d 3e 66 54 72 61 63 65 |.globals|->fTrace|
|00006370| 4f 6e 53 74 61 72 74 75 | 70 20 3d 20 28 42 6f 6f |OnStartu|p = (Boo|
|00006380| 6c 65 61 6e 29 70 61 72 | 61 6d 50 74 72 3b 0d 09 |lean)par|amPtr;..|
|00006390| 09 09 62 72 65 61 6b 3b | 0d 09 20 20 64 65 66 61 |..break;|.. defa|
|000063a0| 75 6c 74 3a 0d 09 09 72 | 65 73 75 6c 74 20 3d 20 |ult:...r|esult = |
|000063b0| 63 6f 6e 74 72 6f 6c 45 | 72 72 3b 09 09 2f 2a 20 |controlE|rr;../* |
|000063c0| 2d 31 37 20 2a 2f 0d 09 | 09 62 72 65 61 6b 3b 0d |-17 */..|.break;.|
|000063d0| 09 09 0d 09 09 7d 0d 0d | 09 67 6c 6f 62 61 6c 73 |.....}..|.globals|
|000063e0| 2d 3e 66 54 72 61 63 65 | 4c 6f 63 6b 20 3d 20 66 |->fTrace|Lock = f|
|000063f0| 61 6c 73 65 3b 0d 09 72 | 65 74 75 72 6e 28 72 65 |alse;..r|eturn(re|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.